乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 63|回复: 4

如何通过VBA获得CAD鼠标获得点来画Polyline并封闭形成多边形,形成完毕再返回执行程

[复制链接]

16

主题

47

帖子

2

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
111
发表于 2004-8-3 17:29:00 | 显示全部楼层 |阅读模式
如何通过VBA获得CAD鼠标获得点来画Polyline并封闭形成多边形,形成完毕再返回执行程序[br]如何通过VBA获得CAD鼠标获得点来画Polyline并封闭形成多边形,形成完毕再返回执行程序
回复

使用道具 举报

12

主题

68

帖子

6

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
116
发表于 2004-8-3 20:33:00 | 显示全部楼层
这是一个获取逐点坐标计算面积的子程序,不知道合不合你的用?我在这里限制了20个点,先生成了一个polyline,然后获取面积,最后删除物体,也许对你没有,写的不好,高手见笑。
Public Sub getab()
'获得逐点面积
Dim p() As Double
Dim p1 As Variant
Dim i As Integer
Dim polyl As Object
On Error GoTo err:
Call AcadOpen
Set acadutil = acadObj.ActiveDocument.utility
AppActivate "Autocad" '
For i = 0 To 59 Step 3
                         p1 = acadutil.Getpoint(, "输入欲调查面积的控制点... ")
                         ReDim Preserve p(i + 2)
                         p(i) = p1(0): p(i + 1) = p1(1): p(i + 2) = 0
                         
Next i
err:
                         If err.Number = -2145320928 Or err.Number = -2145320851 Then
                                                         
                                                         Set polyl = acadObj.ActiveDocument.ModelSpace.AddPolyline(p)
                                                         grid.Text = Round(polyl.Area, sn)
                                                         polyl.Delete
                         Else:
                                                         Exit Sub
                         End If
End Sub
回复

使用道具 举报

72

主题

2726

帖子

9

银币

社区元老

Rank: 75Rank: 75Rank: 75

铜币
3014
发表于 2004-8-4 08:32:00 | 显示全部楼层
Sub Test()
On Error GoTo ErrHandle
Dim pFrom, pTo
Dim p1(3) As Double, p2(1) As Double
Dim pPL As AcadLWPolyline
pFrom = ThisDrawing.Utility.GetPoint(, vbCr & "请输入第一点:")
pTo = ThisDrawing.Utility.GetPoint(pFrom, vbCr & "请输入下一点:")
p1(0) = pFrom(0): p1(1) = pFrom(1)
p1(2) = pTo(0): p1(3) = pTo(1)
Set pPL = ThisDrawing.ModelSpace.AddLightWeightPolyline(p1)
Do While True
pTo = ThisDrawing.Utility.GetPoint(pTo, vbCr & "请输入下一点:")
p2(0) = pTo(0): p2(1) = pTo(1)
pPL.AddVertex (UBound(pPL.Coordinates) + 1) / 2, p2
Loop
ErrHandle:
End Sub
回复

使用道具 举报

16

主题

47

帖子

2

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
111
发表于 2004-8-4 16:36:00 | 显示全部楼层
谢谢!
那请问再如何将 SelectByPolygon应用到程序中选择该区域呢?
回复

使用道具 举报

16

主题

47

帖子

2

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
111
发表于 2004-8-4 20:20:00 | 显示全部楼层
Sub Test()
Dim ssetObj As AcadSelectionSet
Dim CC As AcadCircle
Dim points(0 To 59) As Double
Dim retCoord As Variant
On Error Resume Next
Set ssetObj = ThisDrawing.SelectionSets.Add("TEST_SSET2")
On Error GoTo ErrHandle
Dim pFrom, pTo
Dim p1(3) As Double, p2(1) As Double
Dim pPL As AcadLWPolyline
pFrom = ThisDrawing.Utility.GetPoint(, vbCr & "请输入第一点:")
pTo = ThisDrawing.Utility.GetPoint(pFrom, vbCr & "请输入下一点:")
p1(0) = pFrom(0): p1(1) = pFrom(1)
p1(2) = pTo(0): p1(3) = pTo(1)
Set pPL = ThisDrawing.ModelSpace.AddLightWeightPolyline(p1)
Do While True
pTo = ThisDrawing.Utility.GetPoint(pTo, vbCr & "请输入下一点:")
p2(0) = pTo(0): p2(1) = pTo(1)
pPL.AddVertex (UBound(pPL.Coordinates) + 1) / 2, p2
Loop
ErrHandle:
pPL.Closed = True
'points = pPL.Coordinates
retCoord = pPL.Coordinates
ssetObj.SelectByPolygon acSelectionSetCrossingPolygon, retCoord
For Each CC In ssetObj
On Error Resume Next
CC.color = acBlue
CC.Update
Next CC
ssetObj.Clear
ssetObj.Erase
ssetObj.Delete
End Sub
为什么会在ssetObj.SelectByPolygon acSelectionSetCrossingPolygon, retCoord无法编译过去,请大侠帮我指正,谢谢!
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-7-1 03:35 , Processed in 0.899227 second(s), 62 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表