Dim tlayer as Object
For Each tlayer In acaddoc.Layers
If tlayer.Name = "wall" Then
tlayer.Freeze = acTrue
Else If tlayer.Name="beam" Then
tlayer.LayerOn = acTrue
Set acaddoc.ActiveLayer = tlayer
End If
Next
②创建名为"myview"的新视图
可以通过ActiveX自动实现变换视图角度及缩放全图。
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
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
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>"
全部回复(4 )
只看楼主 我来说两句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",有全部对象的方法、属性说明。
回复 举报
Utility对象提供了与用户在命令行交互的途径,可以让用户输入数字、字符串及角度、点坐标等参量。下面说明如何应用Utility交互替代AutoCad命令中的提示:
Dim acadUtil as Object
Dim stPnt, enPnt As Variant
Dim prompt1, prompt2 As String
Set acadUtil=acaddoc.Utility 设置Utility对象
prompt1 = "起始点: " ‘代替From Point
prompt2 = "终止点: " 代替End Point
stPnt = acadUtil.GetPoint(, prompt1)
enPnt = acadUtil.GetPoint(stPnt, prompt2)
获得用户输入(既可输入坐标值,也可直接在屏幕上选点)
Dim startPoint(0 To 2) As Double
Dim endPoint(0 To 2) As Double
startPoint(0) = stPnt(0)
startPoint(1) = stPnt(1)
startPoint(2) = stPnt(2)
endPoint(0) = enPnt(0)
endPoint(1) = enPnt(1)
endPoint(2) = enPnt(2)
moSpace.AddLine startPoint, endPoint 利用用户输入生成直线
把系统变量设置SetVariable与Utility对象的GetString方法结合,即可向AutoCad的状态行写入内容:
Dim yourname as String
yourname = acadUtil.GetString(0, " 请输入您的姓名: ")
acaddoc.SetVariable "MODEMACRO", yourname & ", 你好!"
5.对非图形对象的操作
非图形对象如层(Layers)、视图(Viewports)、坐标系(UCSs)、块 (Blocks)等与图形实体集合ModelSpace、PaperSpace同是Document对象的子对象,它们本身既是对象,又是对象的集合,如Layers是当前打开的图中所有层的集合,使用Add方法来建立新层,并可以遍历所有层,通过改变其属性达到关闭(Off)、冻结层(Freeze)的目的.
①把层名为"wall"的层冻结,打开层名为"beam"的层,并设为当前层
Dim tlayer as Object
For Each tlayer In acaddoc.Layers
If tlayer.Name = "wall" Then
tlayer.Freeze = acTrue
Else If tlayer.Name="beam" Then
tlayer.LayerOn = acTrue
Set acaddoc.ActiveLayer = tlayer
End If
Next
②创建名为"myview"的新视图
可以通过ActiveX自动实现变换视图角度及缩放全图。
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>"
回复 举报