获取CAD图形边界框(getboundingbox和getvariable)及字外加圆实例应用——vba实现

本文介绍如何使用VBA在AutoCAD中获取图形边界框,并通过实例演示了如何为文字实体添加圆形边界。文章提供了获取边界框的两种方法:getboundingbox方法和获取系统变量方法,并详细展示了循环字外加圆的具体实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        获取某个实体的边界框可用getboundingbox方法(注意:坐标需定义为变体变量variant)

Obj.GetBoundingBox minExt, maxExt

获取整图的边界框可用获取系统变量方法

youshang = ThisDrawing.GetVariable("extmax") '获取系统变量取得整图的边界
zuoxia = ThisDrawing.GetVariable("extmin")

代码如下:

Sub 获取边界框boundingbox()
    'yngqq443440204@2024年4月18日10:55:10
    ' 画条线获取边界框并取得边界框的左下角和右上角坐标(三维)
    Dim startPoint(0 To 2) As Double, endPoint(0 To 2) As Double
    Dim lineObj As AcadLine, youshang As Variant, zuoxia As Variant
    startPoint(0) = 2#: startPoint(1) = 2#: startPoint(2) = 0#
    endPoint(0) = 4#: endPoint(1) = 4#: endPoint(2) = 0#
    Set lineObj = ThisDrawing.ModelSpace.AddLine(startPoint, endPoint)
    ZoomExtents '缩放到范围
    Dim minExt As Variant, maxExt As Variant
    lineObj.GetBoundingBox minExt, maxExt
    ' 获取最小和最大范围
    MsgBox "线的边界范围是:" & vbCrLf _
         & "最小范围: " & minExt(0) & "," & minExt(1) & "," & minExt(2) _
         & vbCrLf & "最大范围: " & maxExt(0) & "," & maxExt(1) & "," & maxExt(2), vbInformation, "qq443440204"
    youshang = ThisDrawing.GetVariable("extmax") '获取系统变量取得整图的边界
    zuoxia = ThisDrawing.GetVariable("extmin")
MsgBox "OK,CAD二次开发qq:443440204", , "qq443440204"
    Stop
End Sub


 结果如下:

 

通过系统变量的方法获取范围比getboundingbox方法获取范围略微大点。

以下为循环字外加圆实例:

Public Sub 循环字外加圆()
'yngqq443440204@2024年4月18日11:48:49
On Error GoTo errorcontrol
Do
Dim objText As AcadText, ptPick As Variant
ThisDrawing.Utility.GetEntity objText, ptPick, "拾取文字:"
Dim ptMin As Variant, ptMax As Variant
objText.GetBoundingBox ptMin, ptMax
Dim ptCenter(0 To 2) As Double
ptCenter(0) = (ptMin(0) + ptMax(0)) / 2
ptCenter(1) = (ptMin(1) + ptMax(1)) / 2
ptCenter(2) = 0
Dim radius As Double
radius = Sqr((ptMin(0) - ptMax(0)) ^ 2 + (ptMin(1) - ptMax(1)) ^ 2) / 2
Dim objCircle As AcadCircle
Set objCircle = ThisDrawing.ModelSpace.AddCircle(ptCenter, radius)
Loop
errorcontrol:
Err.Clear
MsgBox "OK,CAD二次开发qq:443440204", , "qq443440204"
Exit Sub
MsgBox "OK,CAD二次开发qq:443440204", , "qq443440204"
End Sub

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山水CAD插件定制

你的鼓励是我创作最大的动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值