在公路地基處理中可能會遇到鋼釬加固的情況,在作圖之中需要對上千個點逐一編號,重復工作量很大。如果通過編制程序可以提高工作效率,一天的工作量可以在幾分鐘之內解決,而且能夠避免視覺疲勞而引起的錯誤。
AutoDesk公司提供了面向對象的編程接口ActiveXAutomation,它使用了OLE的Automation技術。AutoCAD被登錄為一個其它Windows的應用程序可以操作的對象,用戶可以用VB來訪問AutoCAD的所有圖形對象和非圖形對象,進行二次開發,開發過程完全獨立于AutoCAD本身。
有關VB開發AutoCAD的技術環節,在網上可以找到,特別是崔航的有關文章值得同行借鑒。下面給出程序以及簡單的實現方法步驟。
程序用到的控件有:Command1點擊可連接AutoCAD,并在其中標注鋼釬編號;Command2點擊以釋放AutoCAD所占內存;txtX、txtY輸入編號文字相對于鋼釬點的相對坐標;Text1、Text2編號文字的高度和旋轉角度。現在給出的程序很短而且并不難,就不再作過多注釋。作圖當中先打開鋼釬(在圖中體現為點對象)位置的圖層,然后運行程序,遍歷所有對象并逐一對點對象編號。為節約時間還可以在程序中聲明一個"選擇集"對象,只對選擇集中的對象遍歷。下面給出的程序運行后的結果按畫點的順序,而不是按坐標順序編號,如果有特殊的需要,可以通過相應的排序算法實現。
PrivateSubCommand1_Click()
CallAcadConnect
DimacadUtilAsObject
SetacadUtil=AcadApp.ActiveDocument.Utility'設置Utility對象
DimstxAsDouble
DimstyAsDouble
DimstmStringAsString
stmString=acadUtil.GetString(0,"按任意鍵開始........")
DimiAsInteger
DimoBjAsAcadObject
DimstxxAsVariant
i=1
ForEachoBjInAcadApp.ActiveDocument.ModelSpace'遍歷工作區中的實體
IfoBj.EntityName="AcDbPoint"Then
stxx=oBj.Coordinates
stx=stxx(0)
sty=stxx(1)
CallDrawTxt(stx+Val(txtX),sty+Val(txtY),Val(Text1),0.8,Val(Text2),str(i))
i=i+1
EndIf
NextoBj
EndSub
PrivateSubCommand2_Click()
CallAcadQuit
EndSub
文件模塊
PublicAcadAppAsAcadApplication
PublicSubAcadConnect()'連接Cad
OnErrorResumeNext
SetAcadApp=GetObject(,"autocad.application")
IfErrThen
Err.Clear
SetAcadApp=CreateObject("autocad.application")
IfErrThen
MsgBox"不能運行AutoCAD,請檢查是否安裝!",vbOKCancel,"警告!"
地址: 浙江省.寧波市鄞州區寧姜公路(九曲小區二期旁)
郵編: 315040
聯系人: 盛立峰
電話: 0574-87139378
傳真: 0574-87139378
手機: 13867861670
Copyright ?2004-2025 寧波市鄞州首南恒宇激光雕刻廠 All Rights Reserved.
地址: 浙江省.寧波市鄞州區寧姜公路(九曲小區二期旁) 郵編: 315040 聯系人: 盛立峰
電話: 0574-87139378 傳真: 0574-87139378 手機: 13867861670