wyj7485 发表于 2004-8-6 13:04:00

[转帖]用Visual Basic对AutoCAD进行二次开发

一、引言<BR>                                                                                                                                         AutoCAD一直是CAD市场中的主流产品。随着AutoCAD的日益普及,在其上进行二次开发的工具也不断更新。从早期的Auto <BR>                                                                                                                                       Lisp、ADS、 DCL到现在流行的 Object ARX、ActiveX Automation、Visual <BR>                                                                                                                                       Lisp,均可十分方便地对AutoCAD进行二次开发。本文主要讨论关于运用Visual <BR>                                                                                                                                       Basic对AutoCAD基于ActiveX Automation的二次开发技术。选用 <BR>                                                                                                                                       ActiveX有两个原因,一是因为Visual <BR>                                                                                                                                       Basic的普及性与易用性,二是采用这种方法进行二次开发可方便地实现与其它图形软件的接口,如与Solid <BR>                                                                                                                                       Works实现实体造型与二维绘图的结合,以及根据用户的特殊需要开发出一定功能的软件。<BR>                                                                                                                                         二、ActiveX Automation技术<BR>                                                                                                                                         AutoCAD中的ActiveX <BR>                                                                                                                                       Automation是微软公司ActiveX规范的具体应用。它通过基于ActiveX的自动化对象,为其他应用程序提供了访问AutoCAD内部功能的方法,是AutoCAD最新的开发接口。在运行时,AutoCAD与其他应用程序之间的关系是服务器与客户的关系,开发人员使用支持ActiveX规范的编程语言(如VB、Dephi等)能通过访问AutoCAD的对象模型,把AutoCAD的强大功能集成到应用程序中.AutoCAD的对象模型是一种树型结构模型,根为"AutoCAD <BR>                                                                                                                                       Application",AutoCAD中的所有对象都是AutoCAD <BR>                                                                                                                                       Application的子对象。图1所示为AutoCAD对象模型的层次结构树,其中父对象与子对象之间的关系并不是对象继承关系,而是包含关系。<BR>                                                                                                                                         图1 AutoCAD中ActiveX对象的总结构图<BR>                                                                                                                                         三、ActiveX Automation的使用方法<BR>                                                                                                                                         1. Application对象<BR>                                                                                                                                         如果在计算机系统上安装了AutoCAD,则Windows会自动将其所有的信息注册到系统注册表里。那么在启动Visual <BR>                                                                                                                                       Basic后,用户可以象调用VB自己的对象一样调用AutoCAD所提供的ActiveX。<BR>                                                                                                                                         在编程、调试或运行时至少应该有一个AutoCAD副本在运行。可以通过以下的代码创建AutoCAD对象。<BR>                                                                                                                                         Dim AcadApp as Object '定义一个对象<BR>                                                                                                                                         On Error Resume Next<BR>                                                                                                                                         Set AcadApp =GetObject(,"AutoCAD.Application")<BR>                                                                                                                                         If Err Then '如果没有一个AutoCAD副本在运行<BR>                                                                                                                                         Err.Clear<BR>                                                                                                                                         Set AcadApp =CreateObject("AutoCAD.Application")<BR>                                                                                                                                         AcadApp.Visable =True '启动一个AutoCAD副本并设为可见<BR>                                                                                                                                         If Err Then<BR>                                                                                                                                         MsgBox Err.Description '如果失败,给出错误提示<BR>                                                                                                                                         Exit Sub<BR>                                                                                                                                         End If<BR>                                                                                                                                         End If <BR>                                                                                                                                         2. Preferences与Document对象<BR>                                                                                                                                         与AutoCAD中的Preferences对话框的作用相同,通过Preferences对象可以读取或设置AutoCAD的一些基本设置。Preferences对象通过Application的Preferences属性返回。<BR>                                                                                                                                         Dim AcadPref as Object<BR>                                                                                                                                         Set AcadPref = AcadApp.Preferences<BR>                                                                                                                                         比如,用户可通过Preferences对象进行如下的设置<BR>                                                                                                                                         AcadPref.Cursorsize =100<BR>                                                                                                                                         AcadPref.DisplayScreenMenu =acTrue<BR>                                                                                                                                         AcadPref.DisplayScrollBars =Check1.Value<BR>                                                                                                                                         Document对象表示AutoCAD中中当前打开的文档,对AutoCAD中的任何其它操作都需用到Document对象,该对象可以通过ActiveDocument属性返回。<BR>                                                                                                                                         Dim AcadDoc as Object<BR>                                                                                                                                         Set AcadDoc = AcadApp.ActiveDocument<BR>                                                                                                                                         AutoDesk公司使用了集合的概念。在Document对象中有14个集合,具体如图1所示。与VB中的集合一样,这些集合都支持Add、Item方法与Count属性。例如Add方法可以向该集合中添加一个对象,Item(X)可以的得到该集合中的第X个对象,Count属性可以得到该集合中的对象的个数。<BR>                                                                                                                                         在一个AutoCAD副本运行时,只能同时打开一个 <BR>                                                                                                                                       Document。可以调用Document的New、Save方法以及Saved属性来打开或保存一个AutoCAD文档。<BR>                                                                                                                                         If Not AcadDoc.Saved Then<BR>                                                                                                                                         AcadDoc.Save<BR>                                                                                                                                         Else<BR>                                                                                                                                         Set AcadDoc =AcadDoc.New("acad")<BR>                                                                                                                                         End If<BR>                                                                                                                                         3. 创建、查询与修改AutoCAD图形对象<BR>                                                                                                                                         在创建AutoCAD图形对象之前,首先必须定义并创建ModelSpace与PaperSpace集合对象。这两个对象可通过Document对象的ModelSpace属性与PaperSpace属性返回。<BR>                                                                                                                                         Dim moSpace as Object,paSpace as Object<BR>                                                                                                                                         Set moSpace = AcadDoc.ModelSpace<BR>                                                                                                                                         Set paSpace = AcadDoc.PaperSpace<BR>                                                                                                                                         所有关于图形对象操作的方法与属性都包含在这两个对象中。<BR>                                                                                                                                         创建文本对象:<BR>                                                                                                                                         Dim moSpace as Object <BR>                                                                                                                                         Set moSpace =AcadDoc.ModelSpace<BR>                                                                                                                                         Dim Pnt(0 to 2) as Double '定义一个AutoCAD三维点<BR>                                                                                                                                         Dim TextH as Double '定义字符高度<BR>                                                                                                                                         Dim Textstr as String '定义字符变量<BR>                                                                                                                                         Dim TextObj as Object '定义一个AutoCAD文本对象<BR>                                                                                                                                         Pnt(0) =2:Pnt(1) =4: Pnt(2) =0 '初始化坐标<BR>                                                                                                                                         TextH =1<BR>                                                                                                                                         TexrStr =“This is a test”<BR>                                                                                                                                         Set TextObj=moSpace.AddText(TextStr,Pnt,TextH) '创建文本对象<BR>                                                                                                                                         查询与修改图形对象<BR>                                                                                                                                         有时用户不但要创建图形对象,更多的情况是修改或控制已存在的<BR>                                                                                                                                         对象,这就需要对已创建的对象进行查询,从而得到所要操作的对象。<BR>                                                                                                                                         可以通过属性来得到图形对象的个数。<BR>                                                                                                                                         Dim noMSOBJ as String,noPSOBJ as String<BR>                                                                                                                                         NoMSOBJ=Str(moSpace.Count)<BR>                                                                                                                                         NoPSOBJ=Str(paSpace.Count)<BR>                                                                                                                                         MsgBox "Object:Mspace="&amp; noMSOBJ &amp; ";Pspace="&amp; noPSOBJ<BR>                                                                                                                                         用户也可以通过For..Loop语句来遍历所有的图形对象或是通过方法来得到某个具体的对象。<BR>                                                                                                                                         下面的代码说明了如何来修改当前中的对象,如果对象为一直线,则修改其颜色为红色,否则不做任何改动。<BR>                                                                                                                                         Dim ent as object<BR>                                                                                                                                         For each ent in mospace<BR>                                                                                                                                         If ent.entityname= "acdline" then<BR>                                                                                                                                         Ent.color=acred<BR>                                                                                                                                         Ent.update<BR>                                                                                                                                         End If <BR>                                                                                                                                         Next<BR>                                                                                                                                         需要注意:如果对图形对象做了改动,则需要调用 Update方法在AutoCAD窗口中重画该对象。<BR>                                                                                                                                         同样,可以得到Model Space中最后生成的图形对象。<BR>                                                                                                                                         Dim ent as object<BR>                                                                                                                                         Set ent = moSpace.Item(moSpace.Count-1)<BR>                                                                                                                                         4. 非图形对象<BR>                                                                                                                                         除了ModelSpace与PaperSpace集合,Document对象中另外12个集合中的对象都是非图形对象,如Layers集合包含了AutoCAD当前文档中所有的层,而Linetypes和TextStyles则分别为线型对象与字符型对象的集合。<BR>                                                                                                                                         创建层<BR>                                                                                                                                         可以调用Layers集合的Add方法创建层。以下代码创建一个名称为LAYER1,颜色为洋红色的层。<BR>                                                                                                                                         Dim layerobj as object<BR>                                                                                                                                         Set layerobj =acadDoc.Layers.Add("LAYER1")<BR>                                                                                                                                         Layerobj.Colors=acMagenta<BR>                                                                                                                                         视口<BR>                                                                                                                                         以下的代码使用ActiveSpace属性设置一个活动的Space,然后调用Viewports集合的Add方法创建一个名为"NEW_VIEWPORT"的视口。当视口建立后,Split方法可使原视口与新视口呈上下排列,最后,ActiveViewport属性使新视口成为活动视口。<BR>                                                                                                                                         Dim vport as object<BR>                                                                                                                                         AcadDoc.ActiveSpace=acModelSpace<BR>                                                                                                                                         Set vport=AcadDoc.Viewports.Add("NEW_VIEWPORT")<BR>                                                                                                                                         Vport.Split acViewport2Vertical<BR>                                                                                                                                         Set AcadDoc.ActiveViewport=vport   <BR>                                                                                                                                         5. 用户输入<BR>                                                                                                                                         Document对象中还包含有一个很重要的子对象Utility,Utility对象提供了一些其它的实用功能,如用户输入控制(user-input)。user-input方法可以在AutoCAD的命令提示行中提示用户输入,并显示相应的输入数据类型。这种类型的输入对于屏幕坐标系,实体选择,短字符与数字的输入有着极为重要的应用。<BR>                                                                                                                                         以下的代码定义了Utility对象。<BR>                                                                                                                                         Dim AcadUtil as object<BR>                                                                                                                                         Set AcadUtil =AcadDoc.Utility<BR>                                                                                                                                         每个user-input方法都在AutoCAD的命令行里给出了适当的输入提示并返回相应的数据类型。如:GetString返回一个字符串,GetPoint返回一个点(三个双精度数值)。也可以调用InitializeUserInput方法进行更高级的输入设置。<BR>                                                                                                                                         用户可以定义一个变量:NL=Chr(13)+Chr(10),将这个变量用于输入提示的开始处。<BR>                                                                                                                                         四、结束语<BR>                                                                                                                                         AutoCAD 的ActiveX Automation技术的出现,标志着AutoCAD <BR>                                                                                                                                       的二次开发技术取得了历史性转折。首先,它首次完全实现了OLE <BR>                                                                                                                                       Automation,使得其他软件可以方便地访问AutoCAD;其次,AutoCAD <BR>                                                                                                                                       首次实现了面向对象的开发技术,用户可以操纵它提供所有的AutoCAD 对象;最后,基于ActiveX <BR>                                                                                                                                       Automation开发技术的开发工具得到空前的膨胀,已不再局限于C及C++系列语言,用Visual Basic, <BR>                                                                                                                                       Delphi等工具都可以进行开发。ActiveX Automation技术大大地提高了系统开发的效率、健壮性及易维护性。

torcky 发表于 2004-8-8 21:58:00

好东东!期待楼主继续!

tcchjc 发表于 2004-8-11 13:35:00

您能解决实际问题么?

liub1979 发表于 2004-8-14 00:12:00

xiaohaiclj 发表于 2004-8-14 09:47:00

说的好,需要下载仔细消化

小到中雨 发表于 2007-1-5 11:29:00

<p>请问有事例可以指点以下 么?</p><p></p>

tcsl9621 发表于 2007-1-5 22:12:00

就是太慢了。呵……等半天也打不开CAD。

hanyepiaoyu 发表于 2008-7-1 14:16:00

<p>有没有Autocad VBA 入门到精通</p><p>这本书的电子版本啊</p><p>很难下到</p>

kingchoice00 发表于 2008-7-3 16:49:00

好,我要继续学习

zgjzgjkyo 发表于 2008-7-9 21:32:00

<p>又是这个...妈啊...我次次问人如何在VB下二次开发,个个都是给这个来.</p><p>可惜这个根本不能用的啊..........</p>
页: [1] 2
查看完整版本: [转帖]用Visual Basic对AutoCAD进行二次开发