AutoCAD VBA组块
Sub CreateBlockFromEntities() Dim blockName As String Dim basePoint As Variant Dim selectedEntities As AcadSelectionSet Dim blockDef As AcadBlock Dim blockRef As AcadBlockReference ' 设置图块名称 blockName = "MyBlock" ' 设置图块的基点 basePoint = ThisDrawing.Utility.GetPoint(, "请选择图块的基点: ") ' 创建选择集 On Error Resume Next ThisDrawing.SelectionSets("MySelectionSet").Delete On Error GoTo 0 Set selectedEntities = ThisDrawing.SelectionSets.Add("MySelectionSet") VBA.AppActivate Application.Caption ' 提示用户选择图元 selectedEntities.SelectOnScreen ' 检查是否有图元被选中 If selectedEntities.Count = 0 Then MsgBox "没有选择任何图元。" Exit Sub End If Dim ents() As AcadEntity, i As Long ReDim ents(selectedEntities.Count - 1) For i = 0 To selectedEntities.Count - 1 Set ents(i) = selectedEntities.Item(i) Next ' 创建图块定义 Set blockDef = ThisDrawing.Blocks.Add(basePoint, blockName) ' 将选中的图元添加到图块定义中 ThisDrawing.CopyObjects ents, blockDef ' 插入图块 Set blockRef = ThisDrawing.ModelSpace.InsertBlock(basePoint, blockName, 1#, 1#, 1#, 0) ' 清理选择集 selectedEntities.Delete ' 刷新视图 ThisDrawing.Regen acAllViewports MsgBox "图块创建并插入成功!" End Sub
标签:
Autocad VBA.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!