VB编程添加AutoCAD用户坐标系
2011-06-17 21:08 精诚所至 金石为开 阅读(795) 评论(0) 编辑 收藏 举报用户使用的坐标系一般为世界坐标系,在某些情况下,自定义一个用户坐标系,可使绘图容易,UCS坐标系相对于WCS坐标系可以由平移和旋转,创建UCS语法格式如下。
RetVal=AcadApp.ActiveDocument.UserCoordinateSystems.Add(Origin,xAisPoint,yAxisPoint,Name)
下面的代码在WCS中创建一个长、宽均为4,高为1的立方体,然后再转换到UCS中。
Private Sub Command1_Click()
Dim boxobj As Acad3DSolid
Dim length As Double, width As Double, height As Double
Dim center(0 To 2) As Double
center(0) = 2#: center(1) = 2#: center(2) = 0
length = 4: width = 4: height = 1
Set boxobj = acadapp.ActiveDocument.ModelSpace.AddBox(center, length, width, height)
ZoomExtents
Dim ucsobj As AcadUCS
Dim origin(0 To 2) As Double
Dim xaxispoint(0 To 2) As Double
Dim yaxispoint(0 To 2) As Double
origin(0) = 2: origin(1) = 2: origin(2) = 0
xaxispoint(0) = 4: xaxispoint(1) = 4: xaxispoint(2) = 0
yaxispoint(0) = 0: yaxispoint(1) = 4: yaxispoint(2) = 0
Set ucsobj = acadapp.ActiveDocument.UserCoordinateSystems.Add(origin, xaxispoint, yaxispoint, "ucs1")
acadapp.ActiveDocument.ActiveUCS = ucsobj
acadapp.ActiveDocument.ActiveViewport.UCSIconOn = True
acadapp.ActiveDocument.ActiveViewport.UCSIconAtOrigin = True
Dim transmatrix As Variant
transmatrix = ucsobj.GetUCSMatrix()
boxobj.TransformBy (transmatrix)
End Sub