" />

久久精品电影网_久久久久久电影_久久99精品久久久久久按摩秒播_天堂福利影院_国产男女爽爽爽免费视频_国产美女久久

基于AutoCAD的無屬性的高程圖形數據的處理

所屬欄目:計算機信息管理論文 發布日期:2011-06-07 17:32 熱度:

  摘要:在傳統的測繪方式中,由于受成圖方式和制圖軟件的限制,一些數字化成果的高程數據沒有屬性,給數據處理和利用造成了一定的麻煩。本文通過利用計算機程序解決了這一問題,在實際應用中效果較好。
  關鍵詞:高程;屬性;程序;地形圖
  0、引言
  目前,測繪生產部門大多采用AutoCAD來生成和管理地形圖數據,在CAD中,數據一般是按照地形要素分層存放的。因為各單位繪圖軟件的不同,在生成*.DWG圖時高程點的圖層和點的屬性也不同,有些單位因為軟件的限制,一般把高程注記只是按注記文本在CAD中進行組織和管理。在這種組織方式下,圖形和屬性之間的聯系僅體現在平面位置上的靠近,這就割裂了圖形和屬性之間的關聯,造成了高程數據無法直接讀取和屬性提取。主要缺陷在于:(1)在更換圖的比例尺時候很難根據實際情況均勻的刪除高程注記。(2)很難自動提取異常高程。(3)這種高程數據做不了數字高程模型(DEM)。(4)做不了GIS的屬性數據。(5)在做土方量計算的時候,這種高程數據計算起來相當麻煩。
  在分析了不同時期用不同軟件做出的數字化地形圖之后,我找到了一種好的方法,可以自動刪除多余的高程注記,使高程點根據實際情況均勻分布,可以根據用戶的輸入條件自動刪除異常高程點,可以把沒有屬性的高程點加入屬性,方便做土方量計算和數字高程模型,可以生成GIS需要的三維高程數據文本文件。
  1、實現原理
  首先獲取高程點所在的圖層名稱,其次獲取高程點的屬性,一般為POINT,LWPOLYLINE,CIRCLE,BLOCK等,根據高程點的平面坐標位置獲取離此高程點最近的數字文本注記,判斷是否是高程值,建立文本文件,依次寫入點號、X坐標、Y坐標、Z坐標(也就是離此高程點最近的數字文本注記)。然后刪除所有的高程點,等待用戶輸入:(1)高程點之間的最小距離、(2)用戶認為異常高程點的范圍值,重新繪制帶有屬性的三維高程點,程序流程見圖一。
  
  
  
  圖一:程序框圖
  
  2、程序的實現
  開發CAD的語言有很多,常用的有VLISP、VBA、ARX等,可以根據程序要求選擇一種適合的語言,本程序并不復雜,而且考慮到安全問題,所以選用VLISP語言進行開發,為了減少篇幅,只給出關鍵部分的代碼,如下所述。
  (1)獲取地形圖上的高程點,這里只給出簡單代碼:
  (setqss1(ssget'((-4."<OR")
  (-4."<AND")
  (0."LWPOLYLINE")
  (40.0.125)
  (-4."AND>")
  (-4."<AND")
  (0."INSERT")
  (8."GCD")
  (-4."AND>")
  (-4."OR>")
  …
  …
  )
  )
  )
  (2)根據選擇集中的高程點屬性的不同,分別建立區域選擇集,根據地形圖比例尺的不同,建立的區域選擇集也不同,簡單的語句為:
  (ssget"W"(list…)(list…)'((0."TEXT")))
  (3)寫入文件的語句為
  (write-line(strcat…))
  (4)建立完高程數據文件,就要根據用戶的輸入重新繪制高程點了,這里是本程序的核心部門,主要思路是:首先等待用戶輸入要繪制高程點間的最小距離和異常值的范圍,然后從剛生成的文件里提取高程數據,判斷是不是異常高程,如果不是則在CAD窗口里繪制該高程點,讀下一行數據,如果該數據離剛剛繪制的高程點的距離滿足用戶要求而且不是異常高,則繪制。讀下一行,如果該數據離前面已經繪制的兩個高程點的距離滿足用戶要求而且不是異常高,則繪制,依次例推…。
  主要代碼為:
  (setqpf(open"d:\文件夾\txz.txt""r"))
  (setqi0)
  (setqreco(read-linepf))
  (whilereco
   (setqsxb(flzreco))
   (setqpt(list(atof(nth1sxb))(atof(nth2sxb))(atof(nth3sxb))))
   (set(read(strcat"NUM["(rtosi)"]"))pt)
   (setqreco(read-linepf))
   (setqi(+1i)))
  (closepf)
  (setqi(-i1))
  (setq j0
   t0
   m0
   a0)
  (set(read(strcat"NUM1["(rtos0)"]"))(eval(read(strcat"NUM["(rtos0)"]"))))
  (while(<ji)
  (while(<tm)
  (if(>(distance(list(car(eval(read(strcat"NUM["(rtosj)"]"))))(cadr(eval(read(strcat"NUM["(rtosj)"]")))))(eval(read(strcat"NUM1["(rtost)"]"))))del_dist)
  (setqa(1+a)))
  (setqt(1+t)))
  (if(=am)
   (progn
   (set(read(strcat"NUM1["(rtosm)"]"))(eval(read(strcat"NUM["(rtosj)"]"))))
   (setqm(1+m))))
  (setqa0t0)
  (setqj(1+j)))
  (setqi0)
  (while(<im)
  (command"insert""500"(eval(read(strcat"NUM1["(rtosi)"]")))blcblc"")
  (command"text"(polar(eval(read(strcat"NUM1["(rtosi)"]")))0blc)blc0(rtos(caddr(eval(read(strcat"NUM1["(rtosi)"]"))))2xsd)"")
  (setqi(1+i)))))
  (princ))
  其中flz是一個分解字符串生成表的函數,由于節省篇幅,這里沒有給出具體代碼。
  3、關于程序的一些說明
  不同的地形圖的高程點的屬性可能不同,應根據實際情況,判斷高程點的平面坐標和高程坐標,有的時候判斷高程坐標的時候不能只根據高程點的平面坐標到文字的距離進行簡單的判斷,而且在處理數據量比較大的地形圖時,要考慮程序的優化問題,使它占用計算機內存最小,而且隨時的釋放占用的內存,以達到程序運行穩定,處理速度快,出錯率低。
  參考文獻:
  [1]劉國鈞,陳紹業,王鳳翥.圖書館目錄[M].北京:高等教育出版社,1957 

文章標題:基于AutoCAD的無屬性的高程圖形數據的處理

轉載請注明來自:http://www.56st48f.cn/fblw/dianxin/xinxiguanli/9316.html

相關問題解答

SCI服務

搜論文知識網 冀ICP備15021333號-3

主站蜘蛛池模板: 97色在线视频 | 一区二区三区精品 | 9porny九色视频自拍 | 国产成人精品一区二 | 一区二区三区中文 | 性生生活大片免费看视频 | 欧美精品久久 | 亚洲男人天堂网 | 国产欧美一区二区三区在线看 | 亚洲一区 中文字幕 | 请别相信他免费喜剧电影在线观看 | 亚洲电影成人 | 国产欧美一区二区三区日本久久久 | 日本中文在线 | 青青草原精品99久久精品66 | 久久久亚洲一区 | 国产一区二区在线免费观看 | 日日噜噜噜夜夜爽爽狠狠视频, | 日韩二区 | 欧美国产精品久久久 | 中文字幕乱码视频32 | 国产精品999 | 一区在线观看 | 91国产精品在线 | 美女高潮网站 | 欧美国产一区二区 | japanhd成人 | 男人av网 | 日韩在线小视频 | 激情福利视频 | 成人国产精品视频 | 全免费a级毛片免费看视频免费下 | 国产欧美日韩 | 伊人看片| 能看的av| 欧美aaaa视频 | 国产目拍亚洲精品99久久精品 | 亚洲综合一区二区三区 | 日韩免费看片 | 91高清视频在线 | 国产精品婷婷 |