" />

色偷偷伊人-色偷偷综合-色无五月-色香蕉影院-色亚洲影院

基于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://m.anghan.cn/fblw/dianxin/xinxiguanli/9316.html

相關問題解答

SCI服務

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

主站蜘蛛池模板: 亚洲综合偷自成人网第页 | 中文字幕色婷婷在线精品中 | 中文字幕日本一级高清片 | 好爽好黄的视频 | 色图视频| 婷婷中文 | 免费网站看v片在线成人国产系列 | 99精品国内不卡在线观看 | 免费国产阿v视频在线观看 免费国产高清精品一区在线 | 一本之道无吗一二三区 | 二级黄绝大片中国免费视频0 | 大色香蕉色视频大全 | 综合 欧美 亚洲日本 | 任你躁在线精品视频m3u8 | 黄色日本视频 | 91国内在线国内在线播放 | 一级特黄性色生活片 | 一级日本强免费 | 婷婷丁香综合 | 一级视频网站 | 久久久久欧美精品观看 | 欧美日韩中字 | 国产美女无遮挡免费视频 | 国产精品线在线精品国语 | 亚洲高清网站 | 看日本真人一一级特黄毛片 | 亚洲欧洲日产专区 | 欧美一级做一级爱a做片性 欧美一级做一级做片性十三 | 欧美曰韩一区二区三区 | 欧美搞黄视频 | 美女黄色一级片 | 国产二级毛片 | 大量愉拍情侣在线视频 | 欧美制服 | 婷婷射| 免费黄色国产视频 | 久久精品图片 | 黄色一级视频播放 | 国产一区二区三区在线电影 | 欧美黄色成人 | 好吊色综合网天天高清 |