張豪遠 李勇永
摘 要
數(shù)據(jù)內(nèi)業(yè)處理是地下管線普查的重要內(nèi)容,運用合理的設(shè)計和高效的平臺可以快速地對地下水管線普查數(shù)據(jù)進行內(nèi)業(yè)處理,提高生產(chǎn)效率。為了能夠直觀、科學(xué)的處理,開發(fā)一套普查數(shù)據(jù)內(nèi)業(yè)處理系統(tǒng)甚為重要。本文基于CAD空間數(shù)據(jù)應(yīng)用平臺,以C#為開發(fā)語言,結(jié)合Access數(shù)據(jù)庫實現(xiàn)地下管線普查數(shù)據(jù)內(nèi)業(yè)處理系統(tǒng),并討論如何更好地實現(xiàn)動態(tài)標注、虛線扯旗、提高導(dǎo)出Excel成果數(shù)據(jù)的速度。
關(guān)鍵詞
CAD;地下管線普查;內(nèi)業(yè)數(shù)據(jù)處理;動態(tài)標注;虛線扯旗
中圖分類號: TU990.3 ? ? ? ? ? ?文獻標識碼: A
DOI:10.19694/j.cnki.issn2095-2457.2020.19.068
0 引言
隨著城市化進程的高速發(fā)展,城市管理的復(fù)雜度日益加大,有“城市生命線”之稱的地下管線越顯其重要性[1,2]。為適應(yīng)日新月異的城市建設(shè)要求,開展地下管線普查,構(gòu)建城市地下管網(wǎng)地理信息系統(tǒng),提供準確全面的地下管線資料,是管理正規(guī)化、科學(xué)化、現(xiàn)代化的基石,更是城市實現(xiàn)信息管理的切入點[3,4]。
地下管線普查數(shù)據(jù)內(nèi)業(yè)處理工作量大、步驟多,同時要求有一定的計算機操作知識。為了提高工作效率和簡化處理流程,開發(fā)地下管線普查數(shù)據(jù)內(nèi)業(yè)處理系統(tǒng)甚為重要。因此,本文針對工程實踐的需要,結(jié)合技術(shù)研究需求,基于C#程序設(shè)計語言開發(fā)出一套地下管線普查數(shù)據(jù)內(nèi)業(yè)處理系統(tǒng),該系統(tǒng)采用Access數(shù)據(jù)庫,基于C#+Office2007\Office 2010+AutoCAD2008 \AutoCAD2012開發(fā),可運行在Windows XP、Win7\8環(huán)境中。該系統(tǒng)經(jīng)過數(shù)十個項目的應(yīng)用和不斷完善,錄入、查錯、成圖、編輯、圖庫聯(lián)動和導(dǎo)出等功能大幅簡化了地下管線普查數(shù)據(jù)內(nèi)業(yè)處理的復(fù)雜性,提高了工作效率,為工作、研究提供一定的參考價值。
1 系統(tǒng)的結(jié)構(gòu)組成與功能
一個良好的數(shù)據(jù)管理系統(tǒng)必須對用戶的需求進行調(diào)查分析,使開發(fā)出來的數(shù)據(jù)管理系統(tǒng)盡可能地滿足用戶的需求,同時能方便地對數(shù)據(jù)庫進行有效的管理、維護和使用。根據(jù)地下管線普查數(shù)據(jù)內(nèi)業(yè)處理系統(tǒng)的特點,設(shè)計以下功能(圖1),實現(xiàn)了地下管線普查數(shù)據(jù)快捷、方便的管理,它和管線普查有著同等重要的科學(xué)意義和地位。
1.1 數(shù)據(jù)錄入
系統(tǒng)提供兩種管線數(shù)據(jù)錄入方式:
(1)手動錄入方式:在錄入界面上逐條進行數(shù)據(jù)錄入。
(2)批量導(dǎo)入方式:通過填寫一定格式的Excel表,批量導(dǎo)入。
1.2 數(shù)據(jù)查錯
系統(tǒng)包含豐富的查錯內(nèi)容,包括物探點號檢查(對物探點號的規(guī)范性進行檢查,包括管線點號長度和編碼方式等)、管徑檢查(檢查管徑的容限范圍,以及斷面尺寸與孔數(shù)、根數(shù)、埋設(shè)方式等的邏輯性等)、埋深檢查(檢查埋深容限范圍,以及和管徑、埋設(shè)方式的邏輯性等)、直通點檢查(檢查直通點各項屬性的邏輯性)、起止點檢查(檢查管線的連接關(guān)系,確保管線連接正確)、排水流向檢查(檢查排水管線的流向邏輯性)、重復(fù)線檢查(檢查管線是否重復(fù))、輔助線檢查(檢查輔助線的連接關(guān)系,以及平面位置)、高程檢查(檢查高程容限值以及管線埋深和高程異常)、共通邏輯性檢查(檢查共通管類的根數(shù)孔數(shù)等)等,并可以根據(jù)各地規(guī)范拓展新的查錯功能。
1.3 數(shù)據(jù)成圖
系統(tǒng)可以自動讀取管點或管線段的屬性信息,并按照規(guī)定的圖層、顏色、線型、符號等要求生成管線圖;同時將數(shù)據(jù)庫中的屬性信息自動標注到對應(yīng)的管線點或管線段,并在圖上展示出來。
1.4 數(shù)據(jù)編輯
系統(tǒng)提供修改符號角度、打斷加點、連接管點、數(shù)據(jù)更新、數(shù)據(jù)復(fù)制、數(shù)據(jù)刪除等多種編輯方式。
1.5 圖庫聯(lián)動
為方便數(shù)據(jù)修改,系統(tǒng)提供兩種圖庫聯(lián)動方式。
1)通過修改管線圖對數(shù)據(jù)庫進行修改;
2)通過對數(shù)據(jù)庫的修改可直接反饋到管線圖中,自動更新圖形中有關(guān)的符號、線型、角度、注記等屬性。
1.6 數(shù)據(jù)導(dǎo)出
系統(tǒng)支持三種格式的成果數(shù)據(jù)導(dǎo)出。
1)Excel格式的成果表導(dǎo)出;
2)Mdb格式的成果數(shù)據(jù)庫導(dǎo)出;
3)Dwg格式的綜合圖、專業(yè)圖標準圖幅導(dǎo)出。
2 系統(tǒng)功能的實現(xiàn)
根據(jù)上述的分析和對數(shù)據(jù)庫的設(shè)計。對系統(tǒng)進行了程序設(shè)計和開發(fā),經(jīng)過運行、調(diào)試,并最終開發(fā)出一套地下管線普查數(shù)據(jù)內(nèi)業(yè)處理系統(tǒng)軟件。核心功能如下:
2.1 動態(tài)標注
為了快速查看管線、管點要素的屬性信息,系統(tǒng)增加了動態(tài)提示功能,即鼠標懸停在管線、管點要素上時顯示其屬性信息。該功能主要依靠CAD中Editor的鼠標懸停PointMonitor事件來實現(xiàn)。
Editor editor = document.Editor;
editor.PointMonitor+=new PointMonitorEventHandler(editor_PointMonitor)
具體為在PointMonitor事件中,采用e.AppendTool TipT ext( )方法實時捕捉并顯示管線、管點要素的屬性信息。
2.2 虛線扯旗
在進行綜合圖制作時,需要對管線要素進行扯旗標注信息,但有些管線要素符號化時采用的是虛線線型,存在虛線線型的管線要素信息不會顯示的情況。為解決這一問題,在標注扯旗信息前,先查找扯旗范圍內(nèi)的虛線線型要素并存儲在一個數(shù)組中,然后把其線型改為實線,在標注扯旗信息后,再把其線型改為之前的虛線線型,代碼實現(xiàn)如下。
2.3 導(dǎo)出Excel速度優(yōu)化
在導(dǎo)出Excel成果表時,需要從Access數(shù)據(jù)庫中把管線、管點數(shù)據(jù)填寫到Excel文件中。以1000公里管線為例,采用:
這種方式需要1小時左右,如果優(yōu)化使用下述方式:
優(yōu)化前,執(zhí)行的是對每個Excel單元格進行寫入操作,優(yōu)化后,執(zhí)行的是將需要寫入的數(shù)據(jù)放到數(shù)組objLineValues中,然后統(tǒng)一粘貼到Excel表的對應(yīng)行中。在同樣的數(shù)據(jù)量下,優(yōu)化后的方式只需要十分鐘左右,提高了5倍的效率。
2.4 系統(tǒng)一鍵安裝和卸載
為了方便用戶快速部署系統(tǒng),在系統(tǒng)安裝目錄下創(chuàng)建了“一鍵安裝.vbs”、“一鍵卸載.vbs”兩個腳本文件,可分別點擊一鍵安裝和卸載。
3 結(jié)語
針對地下管線的特點以及普查數(shù)據(jù)業(yè)內(nèi)處理、管理等遇到的問題,結(jié)合工程需求,本文闡述了如何運用C#語言程序開發(fā)一套地下管線普查數(shù)據(jù)內(nèi)業(yè)處理系統(tǒng),詳細介紹了系統(tǒng)的結(jié)構(gòu)組成與功能,實現(xiàn)了動態(tài)標注、虛線扯旗、Excel成果數(shù)據(jù)導(dǎo)出的優(yōu)化,為工程實踐等提供了一定的參考價值。
基于C#+CAD的地下管線普查數(shù)據(jù)內(nèi)業(yè)處理系統(tǒng)不但支持多個操作系統(tǒng)、多個CAD版本,大幅簡化了管線普查數(shù)據(jù)內(nèi)業(yè)處理的復(fù)雜性,而且能快速部署,同時界面簡潔、操作簡單,即使沒有經(jīng)驗的人也很容易上手。但受制于CAD版本的限制,該系統(tǒng)目前還不支持多線程成圖,需要后期升級到AutoCAD 2014版本。
參考文獻
[1]張國林.城市地下管線普查數(shù)據(jù)處理系統(tǒng)設(shè)計[J].東北測繪,2002(03):50-51+56.
[2]王聿賀.淺談城市地下管線普查內(nèi)業(yè)處理方法[J].科技創(chuàng)業(yè)月刊,2015,28(17):114-115.
[3]陳麗佳,符湛斌.基于EPS廣州市地下管線普查及數(shù)據(jù)升級的實踐與探究[J].北京測繪,2017(04):144-146+158.
[4]孫玉晶. 淺析城市地下管線內(nèi)業(yè)數(shù)據(jù)處理[J].勘察測繪,2017(6):240.