Public Sub changeview(ByVal x, ByVal y, ByVal z)
Dim newDirection(0 To 2) As Double
Dim vport As Object
acaddoc.ActiveSpace = acModelSpace ‘使ModelSpace成为活动
空间
Set vport = acaddoc.Viewports.Add("newview") ‘建立新视图
newDirection(0) = x
newDirection(1) = y
newDirection(2) = z ‘视图的视角方向
vport.Direction = newDirection
acaddoc.ActiveViewport = vport ‘把新视图激活
acaddoc.ActiveViewport.ZoomAll ‘全图显示
End Sub
以上例程是对Layers、Viewports对象的举例,其他非图形对象的引用与此类似。
6.对选择集的操作
在对AutoCad的编程中,选择集占有十分重要的地位,对编程者而言,并不清楚图中包含什么实体,只有通过用户的选择或通过过滤条件把所需的实体加入选择集,再对选择集中的实体进行操作。下面例程给出了两种筛选建立选择集的方法,把图中所有在层"wall"上的直线亮显。
①由用户在屏幕上选择实体
Dim tempset as Object
Dim obj as Object
Set tempset = acaddoc.SelectionSets.Add("newset") '建立新选择集
tempset.SelectOnScreen ‘用户在屏幕上选择
For Each obj In tempset ‘遍历选择集中的实体
If obj.EntityName="AcDbLine" And obj.Layer="wall" Then
obj.HighLight(True) '亮显实体
End IF
Next
这种选择方式给用户较大的自由,但不能保证选择集内包含所有我们期望的实体,若要精确过滤出所需实体,应该给选择集加入条件。
②使用过滤器(Filter)筛选实体
Dim actualCode(3) As String
Dim actualValue(3) As String
Dim groupcode As Variant
Dim groupValue As Variant
Dim extminpt(2) As Double
Dim extmaxpt(2) As Double
Dim tsset As Object
Dim tobj As Object
actualCode(0) = -4
actualValue(0) = " actualCode(1) = 8
'保证 Layer是"wall"
actualValue(1) = "wall"
actualCode(2) = 100
actualValue(2) = "AcDbLine" '所选实体为直线
actualCode(3) = -4
actualValue(3) = "AND>"
extminpt(0) = 0
extminpt(1) = 0
extminpt(2) = 0
extmaxpt(0) = 800
extmaxpt(1) = 400
extmaxpt(2) = 0 ‘设选择集涉及区域的左上点与右下点坐标
groupcode = actualCode
groupValue = actualValue
Set tsset = acaddoc.SelectionSets.Add("SS2")
tsset.Select acSelectionSetAll, extminpt, extmaxpt, groupcode,_ groupValue ‘加了过滤器的选择集
For Each tobj In tsset
tobj.HighLight(True)
'tobj一定满足既是直线,又在层"wall"上
Nexe
上述变量中groupcode是组码,groupValue是组码下的值。只要找出相应的组码及其下的值,配合条件(And Or Not等,组码为-4)的使用,便可以构造出任意的过滤器,迅速获取所需实体的集合。
7.SendKeys的妙用
AutoCad的ActiveX虽然强大,但不是所有问题都可以通过它解决。要在VB中使用AutoCad对象没有的方法,就须用到VB中的过程SendKeys。通过SendKeys把AutoCad的命令行如同批处理一样送到AutoCad中自动执行,在效果上与使用对象的方法是相同的。另外,还可以使用简单的AutoLisp语言增强AutoCad命令行的功能。下例是执行break命令而编写的过程。其中的(handent"***")是从Lisp语言中借来的,可以直接在命令行通过实体句柄(Handle)来确定实体。
SendKeys "{esc}", True
SendKeys "{esc}", True ‘避免以前命令的干扰
SendKeys "_break" & "{enter}", True
SendKeys "{(}" & "handent" & """" & wallhandle & """" & "{)}" & "{enter}", True ‘选择要断开的实体(wallhandle为其句柄)
SendKeys Format(cood1(0)) & "," & Format(cood1(1)) & "{enter}", True
SendKeys Format(cood2(0)) & "," & Format(cood2(1)) & "{enter}", True ‘cood1与cood2是实体上断开点的坐标
三、 最终的补充说明
1. 尽量采用迭代的方法遍历集合
如前所述,对CAD的编程中涉及大量的集合操作,下面的代码段与迭代法效果相同,但效率较低。
Dim I As Integer
For I=0 To sset.Count-1
sset(I).HighLight(True)
Next I
在创建自己的集合时,关键字尽量采用Handle值,以便查找,并可通过HandletoObject方法将Handle值转化为实体(Object)
2.
采用AutoCad r14.01版
Autodesk公司在r14版中加入了ActiveX
Automation,但尚不完善。在随后推出的14.01版中,Autodesk公司解决了r14版的不少错误,使得应用程序运行更为流畅、稳定。如果要进行AutoCad的ActiveX编程,建议采用VB5.0和AutoCad
r14.01。
3.
关于ActiveX的资源
国内有不少介绍ActiveX编程及AutoCad的资料,但迄今还未发现有完整讨论AutoCad的ActiveX编程的书籍,目前最容易得到的资料就是Autodesk公司编写的随机帮助,其中有一章“ActiveX
Automation",有全部对象的方法、属性说明。
此处推荐几个有关网址:
Autodesk公司主页:www.autodesk.com
文章整理:西部数码--专业提供域名注册、虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!




