明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1401|回复: 2

[VBA]删标标注:提示空指针对象错误?有代码

[复制链接]
发表于 2005-6-3 08:39:00 | 显示全部楼层 |阅读模式
这段程序是建立一个选择集,将标注对象加入选择集,把所有的标注都删除 当然,有更好的办法更好,请看一下下面的代码 Set ACADapp = GetObject(, "AutoCAD.Application")
Set ACADdoc = ACADapp.ActiveDocument
Dim ssetObj As AcadSelectionSet
ACADapp.ActiveDocument.SelectionSets("TEST_SELECTIONSET").Delete
Set ssetObj = ACADapp.ActiveDocument.SelectionSets.Add("TEST_SELECTIONSET")

Dim i As Long
Dim obj As AcadObject i = 0
For Each obj In ACADapp.ActiveDocument.ModelSpace '遍历工作区中的实体
Select Case obj.EntityName
Case "AcDbMText", "AcDbText", "AcDbRadialDimension", "AcDb3PointAngularDimension", "AcDbRotatedDimension", "AcDbAlignedDimension", "AcDbOrdinateDimension", "AcDbFcf", "AcDbLeader"
i = i + 1
Case Else
End Select
Next obj MsgBox i
ReDim ssobjs(0 To i) As AcadEntity i = 0
For Each obj In ACADapp.ActiveDocument.ModelSpace '遍历工作区中的实体
Select Case obj.EntityName
Case "AcDbMText", "AcDbText", "AcDbRadialDimension", "AcDb3PointAngularDimension", "AcDbRotatedDimension", "AcDbAlignedDimension", "AcDbOrdinateDimension", "AcDbFcf", "AcDbLeader"
Set ssobjs(i) = ACADapp.ActiveDocument.ModelSpace.Item(i)
i = i + 1
Case Else
End Select Next obj
MsgBox i

ssetObj.AddItems ssobjs '这句老提示空对象指针,是怎么回事

ssetObj.Erase
发表于 2005-6-5 07:58:00 | 显示全部楼层
i值指的是选择到的图元数量,但循环却是从0-i,也就是需要i+1的图元数量。所以在你的程序中,ssobjs(i)数组的最后一个元素并未被赋值。
 楼主| 发表于 2005-6-6 10:08:00 | 显示全部楼层
问题已解决,谢谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-27 14:28 , Processed in 0.153581 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表