本文介绍了VBA二次开发AutoCAD的技术特点,并以实例说明VBA应用程序的编写要点。进一步验证了AUTOCAD与VBA以Activex Automation自动化接口技术实现连接,利用VB的可视化编程设计实现CAD系统设计的实际价值。
1引言
AutOCAD2005是AutOdesk公司的系列产品,该软件从其使用和设计思路上都秉承了工程制图人员的绘图习惯,能够非常轻松地绘制出带有平面视图和三维渲染效果的工程图纸,是绘图人员的一个理想工具。随着CAD基础理论和应用技术的不断发展,对CAD系统的功能要求也越来越高。因而AutoCAD不可能完全满足每个用户的具体而特定的要求。设计人员希望它能从本质上减轻大量简单烦琐的工作量,使他们能集中精力于那些富有创造性的高层次思维活动中。
AutoCAD提供的开放式体系结构允许用户和开发者采用高级编程语言对其进行扩充和修改,即二次开发,能最大限度地满足用户的特殊要求,更方便、更规范、更专业的实现设计和绘图中的应用。VBA最早是建立在0ffice97中的标准宏语言,由于它在开发方面的易用性及具有的强大功能,许多软件开发商都将其嵌入自己的应用程序中,作为一种开发工具提供给用户使用。AutOdeSk公司自从Aut0CADRl4.0l版开始,内置了VBA开发工具。
新一代程序开发工具ViSual BaSic,不仅继承了面向对象方法的特性,同时具备可视化程序语言及程序产生器的概念。
VBA(visual Basic For Apphcation)是AutoCAD R12以后推出的一种新的编程环境,提供了以Visual Basic为基础的面向对象的开发特征及程序接口,能真正快速地访问AutOCAD图形数据库,能明显提高软件开发和维护的效率。
2 VBA的技术特性
2.1 VBA开发AUTOCAD的技术特点
VBA是微软开发出来的应用程序共享一种通用的自动化语言,它可以使常用的程序自动化,并可以创建自定义的解决方案。
VBA被集成到AutoCAD中,VBA和AutoCAD中强大的Activex自动化对象模型的结合,代表了一种新型的定制AutoCAD的模式构架。通过VBA,我们可以操作AutoCAD2004,控制ActiveX和其它一些应用程序,使之相互之间发生互易活动下面就是VBA的主要功能:
(1)VBA提供强大的窗体创建功能,为应用程序建立对话框及其他屏幕界面。
(2)可以创建自己的工具条。
(3)可以创建功能强大的模块级宏指令,宏名实质上就是模块的过程名。
(4)提供建立类模块的功能,这对开发大型工程非常有用,因此类可以提供重用组。
(5)具备完善的数据访问和管理能力,通过ADO(ActivexData Objects),可以对Access数据库或其他外部数据库(像dBase,FoxPro等)实现访问和管理。此功能比直接使用AutoCAD的数据库管理系统要方便,且功能强大。
2.2 VBA AutoCAD ActiveX Automation对象模型
VBA是通过AutoCAD ActiveX Automation接口来建立和AutoCAD对象问的联系。ActiveX是建立在COM对象模型之上的一个标准通信协议,它允许对象之间通过一定的接口相互通信。
AutoCAD Activex使用户能够从AutoCAD的内部或外部以编程方式来操作AutoCAD。它是通过将AutoCAD对象显示到“外部世界”来做到这一点的。这些对象被显示后,许多不同的编程语言和环境以及其他应用程序(例如Microsonword VBA或Excel VBA)就可以访问它们。如图1是编程语言和应用程序通过AutoCAD ActiveX访问AutoCAD。
图1 编程语言和应用程序通过AutoCAD AcfiveX访问AutoCAD
在AutoCAD中实现ActiveX接口有两大优点:
·更多的编程环境可以编程访问AucOCAD图形。在ActiveXAutomation出现以前,开发人员只能使用AutoLISP或C++接口。
·与其他windows应用程序(如Microsoft ACCESS和Word)共享数据变得更加容易。
对象是所有Activex应用程序的主要构造块。每一个显示的对象均精确代表一个AutoCAD组件。AutoCAD ActiveX接口中有许多不同类型的对象。例如:
·直线、圆弧、文字和标注等图形对象都是对象。
·线型与标注样式等样式设置都是对象。
·图层、编组和块等组织结构都是对象。
·视图与视口等图形显示都是对象。
·甚至图形、AutoCAD应用程序本身也是对象。
AutoCAD对象是通过分层方式来组织的,应用程序对象为根对象。这种分层结构的视图被归结为对象模型。对象模型提供了用户访问下一层对象的途径。
用户可直接通过用户定义变量引用对象。直接引用对象,应包括对象的层次。举一个最简单的例子,在VBA中要利用圆心和半径创建圆可以使用以下代码:
Sub drawcircle()
* Dim ptl(2)As Double
Dim radius As Double
ptl(0)=23
ptl(1)=78
Dtl(2)=67
radius=56
’调用Addcircle方法绘制圆
ThisDrawing.Modelspace.addcircle ptl,radiusEnd Sub
3 AUTOCAD VBA实例应用
这个实例,介绍了VBA开发AUTOCAD实现参数化绘图的编程思路与实际应用,是CAD系统中很重要的环节。
3.1绘制三维图形实例说明
(1).本程序运行界面如图2所示,用户可以指定中心点,桌面及桌腿半径,桌子的高度,系统就能根据用户指定的参数在三维空间中创建出一个桌子。
(2).编程思路
核心问题是创建大小圆的面域,复制出来的桌腿,角度的旋转及最后的合并着色。
3.2 VBA开发AutoCAD2005的技术流程
(1)首先在AUTOCAD2004中,选择[工具/宏/VBA管理器]菜单项,在弹出的[VBA管理器]对话框中单击[新建]按钮,将其保存在适当的位置。
(2)在[VBA管理器]对话框中单击[Visual Basic编辑器]按钮,进入VBA集成开发环境,选择[插入/用户窗体]菜单项,向工程中添加一个用户窗体。
图2 创建桌子运行界面
(3)在用户窗体上插入如图2所示的相关控件,并按下表分别设置它们的相关属性。
(4)相关代码:l>.在Cammandbutton2命令按钮的单击Click事件的代码为:
图3桌子的参数化绘图
(2)在AutoCAD2004中,选择[视图/着色/体着色]菜单项,对生成的模型进行着色,所得结果,如图4所示
图4 创建桌子运行界面
该实例可以连接上数据库,使用时可以直接调用数据库中的参数,直接运行得出所需的图形。
4 AUTOCAD VBA数据库连接技术
4.1 ADO数据库访问技术
别随着CAD技术的发展,在CAD软件中使用数据库的场合越来越多,数据库连接方法ADO是Microsoft AcciveX Data ObjeCts的简称,ADO作为一种更新的数据库访问技术,“扩展”了DA0和RD0所使用的对象模型,包含较少的对象和更多的属性、方法、事件。
本节仅介绍ADO控件连接MICROSOFT、ACCESS数据库的基本操作,桌子的各个参数,存放在数据库DESK.mdb中,可以用于浏览数据库中的各条记录,还可以完成记录的添加,修改和删除操作。
在使用ADO对象之前,需要在VBA集成开发环境中,选择[工程/引用]菜单项,从弹出的对话框中选中[microsoft ActiveX Data Objects 2.5 Livrary]选项,引用ADO的对象模型,如图5所示
图5 引用ADO的对象模型
4.2 ADO编程
在编程过程中使用AD0的一个典型的存取数据的步骤为:
(1)连接数据源。可以使用连接对象的Open方法打开数据库对象,例如:
adoCon.Open“Provider=Microsoft.Jet.OLEDB.4.0;DataSource=“&_
Left(strPath,Len(strPam)一6)&”\DESK.mdb;”
(2)打开记录集对象。可以使用记录集对象的Open方法打开记录集对象,例如:
adoRs.Open“biaoData2”,adoCon,adOpenDynamic,adLockOptimiStic
(3)使用记录集。在各个记录集之间切换一般可以使用记录集对象的Move、MoveFirst、MoveNext、MovePrevious和MoveLast方法,添加新的记录可以使用记录集对象的AddNew方法,修改当前记录的内容只需对数据库记录集中的对象重新赋值即可,删除当前的记录可以使用记录集的Delete方法。
其中,记录集在进行添加的操作之后,必须使用Update方法更新数据库。
(4)断开连接。使用close方法能够关闭记录集和数据库连接对象,在退出程序之后,必须用close方法关闭这两个对象。向工程中添加一个用户窗体,并在窗体中放置如图6所示的控件。
向工程中添加一个用户窗体,并在窗体中放置如图6所示的控件。
图6桌子的数据库连接
5 结束语
基于VBA的AutoCAD二次开发技术,可以实现AUTOCAD功能的拓展及参数化没计,如零件标准图库的建立等各个方面,更好的满足机械电子行业等系列化产品的专业设计。对于大型CAD应用软件的开发,能发挥极大的作用。各大企业也在开发自己的CAD系统,具有很好的实用价值。