" />

国产黄色毛片-国产黄色毛片视频-国产黄色片91-国产黄色片一级-一级坐爱片-一级免费

VBA實現(xiàn)AutoCadMap下電桿符號批量轉(zhuǎn)換

所屬欄目:電子技術(shù)論文 發(fā)布日期:2012-10-13 10:49 熱度:

  摘要:AutoCADMAP是我們所熟知的地理信息制圖的重要軟件之一,它不僅操作方便,而且功能十分強大.但由于我們需求的多樣性,它在有些方面已經(jīng)不能滿足我們的需求.因此需要我們自己開發(fā)些功能來解決我們的需求問題.AutoCADMAP提供了強大的VBA開發(fā)技術(shù),為我們實現(xiàn)AutoCADMAP的二次開發(fā)提供了有效的途徑.本文在為提高生產(chǎn)效率與準確度的環(huán)境下,基于VBA開發(fā)實現(xiàn)了AutoCADMAP電桿符號的批量轉(zhuǎn)換.
  關(guān)鍵詞:VBA,電桿符號,AutoCADMAP
  1引言
  所謂電桿符號既電力機車軌道兩旁的電桿.在我們進行數(shù)字化的時候,軌道載CAD中是一條平行雙線,而電桿則是作為符號分布在平行線的兩側(cè),而且要求符號的方向要垂直于軌道方向.通常一條軌道兩側(cè)總計會有幾千個電桿符號,如果人工操作,則需要對每個符號進行處理,旋轉(zhuǎn).這將極大的降低工作效率,而且準確度也得不到保障.為解決這種需求。AutoCADMAP提供了強大的VBA開發(fā)技術(shù),為我們實現(xiàn)AutoCADMAP的二次開發(fā)提供了必要的接口,使我們能通過這些接口和VBA語言實現(xiàn)CAD電桿符號的批量轉(zhuǎn)換。
  2系統(tǒng)目標
  利用VBA語言與AutoCADMAP二次開發(fā)接口的結(jié)合,編寫程序?qū)崿F(xiàn)電桿符號的批量轉(zhuǎn)換,提高生產(chǎn)效率,增強準確度.
  3系統(tǒng)設(shè)計方案
  (1)數(shù)據(jù)錄入,把要數(shù)字化的電力機車軌道和符號輸入到AutoCADMAP中,電桿符號中心線的末端要畫在軌道上或穿過軌道,如圖1所示:
  
  圖1
  (2)利用AutoCADMAP的打斷相交線工具,把剛才繪制的所有相交線打斷,刪除多余的部分,如圖2所示:
  
  圖2
  (3)通過以上兩個步驟,使電力機車軌道變成了很多條線段,使每相鄰兩個電桿符號都有一段獨立的機車軌道,通過編程獲取這段機車軌道的方向(線角度),把電桿符號分別相對這個角度旋轉(zhuǎn)正90度,負90度.通過程序分別選擇所有的軌道和電桿符號,通過遍歷,最終達到效果如圖3所示:
  
  圖3
  4主要程序代碼:
  SubDIANGAN()
  DimlayerObjAsAcadLayer
  SetlayerObj=ThisDrawing.Layers.Add("GBLOCK")
  DimAngleFirstAsDouble
  DimAngleSecondAsDouble
  DimselsetAsAcadSelectionSet
  DimselAsAcadSelectionSet
  DimFilterType(0)AsInteger
  DimFilterData(0)AsVariant
  DimvarAAsVariant
  DimvarBAsVariant
  DimintIAsInteger
  FilterType(0)=0
  FilterData(0)="LWPOLYLINE"
  varA=FilterType
  varB=FilterData
  IfThisDrawing.SelectionSets.Count<>0Then
  ForintI=0ToThisDrawing.SelectionSets.Count-1
  Setselset=ThisDrawing.SelectionSets.Item(intI)
  selset.Delete
  OnErrorResumeNext
  NextintI
  EndIf
  sset.Delete
  Setselset=ThisDrawing.SelectionSets.Add("SS3")
  selset.SelectOnScreenFilterType,FilterData
  Setsel=ThisDrawing.SelectionSets.Add("SS4")
  FilterType(0)=0
  FilterData(0)="LWPOLYLINE"
  sel.SelectOnScreenFilterType,FilterData
  DimpobAsAcadLWPolyline
  DimPOB2AsAcadLWPolyline
  DimJpointAsVariant,TpointAsVariant
  DimblockBHAsAcadBlockReference
  DimstrDirNameAsString
  Dimbj(10000,2)AsDouble
  DimrAsInteger,jAsInteger,cjAsInteger
  strDirName="D:G500編輯程序dqhtl.dwg"
  r=0
  cj=0
  ForEachpobInselset
  ForEachPOB2Insel
  cj=0
  Jpoint=pob.IntersectWith(POB2,acExtendNone)
  IfUBound(Jpoint)>0Then
  Forj=0Tor-1
  IfJpoint(0)=bj(j,0)AndJpoint(1)=bj(j,1)Then
  cj=cj+1
  EndIf
  Nextj
  bj(r,0)=Jpoint(0)
  bj(r,1)=Jpoint(1)
  r=r+1
  Ifcj>0Then
  Else
  Dimpp(2)AsDouble
  pp(0)=Jpoint(0)
  pp(1)=Jpoint(1)
  pp(2)=0
  DimkAsInteger
  Fork=0ToUBound(pob.Coordinates)
  Ifpob.Coordinate(0)(0)=Jpoint(0)Andpob.Coordinate(0)(1)=Jpoint(1)Then
  CallAngle(pob.Coordinate(0)(0),pob.Coordinate(0)(1),pob.Coordinate(1)(0),pob.Coordinate(1)(1),AngleFirst,AngleSecond)
  Else
  k=(UBound(pob.Coordinates)+1)/2-1
  CallAngle(pob.Coordinate(k-1)(0),pob.Coordinate(k-1)(1),pob.Coordinate(k)(0),pob.Coordinate(k)(1),AngleFirst,AngleSecond)
  EndIf
  Nextk
  SetblockBH=ThisDrawing.ModelSpace.InsertBlock(pp,strDirName,0.1,0.1,0.1,AngleFirst)
  blockBH.Layer="GBLOCK"
  SetblockBH=ThisDrawing.ModelSpace.InsertBlock(pp,strDirName,0.1,0.1,0.1,AngleSecond)
  blockBH.Layer="GBLOCK"
  EndIf
  EndIf
  NextPOB2
  Nextpob
  EndSub
  5結(jié)束語
  AutoCADMAP二次開發(fā)接口和VBA語言的結(jié)合所產(chǎn)生的作用是非常強大的,本文所實現(xiàn)的功能只是它的一個簡單的典型應(yīng)用,它個更多功能還需大家去發(fā)掘去體會。
  參考文獻
  
  [1]AutoCAD+VBA二次開發(fā)來源:InterNet明經(jīng)通道

文章標題:VBA實現(xiàn)AutoCadMap下電桿符號批量轉(zhuǎn)換

轉(zhuǎn)載請注明來自:http://m.optiwork.cn/fblw/dianxin/dianzijishu/13488.html

相關(guān)問題解答

SCI服務(wù)

搜論文知識網(wǎng) 冀ICP備15021333號-3

主站蜘蛛池模板: 午夜欧美性欧美 | 国产黄色片在线观看 | 成人影院一区二区三区 | 国产成人夜间影院在线观看 | 久草手机在线观看 | 日本一级看片免费播放 | 欧美日韩国产亚洲一区二区 | 国产精品亚洲欧美日韩区 | 国产日韩一区二区三区在线观看 | 久草免费资源视频 | se94se欧美| 中文字幕精品视频在线 | 欧美韩国xxx | 国内精品久久久久久网站 | 欧美日韩午夜视频 | 亚洲免费观看 | 天天鲁天天爱天天鲁天天 | 久久在线视频免费观看 | 国产欧美日韩精品第二区 | 国产精品色午夜视频免费看 | 欧洲美女a视频一级毛片 | 黄色va视频| 国产在线黄| 一级高清毛片免费a级高清毛片 | 18videosex性欧美69超高清 | 欧美一区二区在线免费观看 | 9cao视频精品| 在线观看国产情趣免费视频 | 欧美一级aa毛片禁片 | 国产精品国产三级国产专播 | 免费一级淫片aaa片毛片a级 | 黄色三级网站在线观看 | 三级网站免费看 | 黄色三级欧美 | 成人三级视频在线观看 | 精品国产中文一级毛片在线看 | 夜夜爱夜夜爽夜夜做夜夜欢 | 国产一区日韩二区欧美三 | 午夜三级毛片 | 亚洲国产成人久久综合碰 | 特黄的欧美毛片 |