|
回复 #7 truezx 的帖子
下面是附件中的代码/ J! g6 B; ?' n
- Private Sub AcadDocument_ObjectModified(ByVal Object As Object) '在thisdrawing对象的代码模块声明一个事件过程,当文档被修改时执行其中的代码
) [- b2 e# [" `# M - Dim S As AcadSelectionSet, T As Object, P As AcadLWPolyline0 q. O( j) i' x- D
- If Object.Handle = "2D67C" Then '当被修改的对象为指定的动态块中的正方形时执行下面的代码。"2D67C"是本文档中该正方形的句柄/ H5 r6 r$ W) d% O+ }& c/ Y( M
- Set S = ThisDrawing.SelectionSets.Add("SS") '新建选择集并选择屏幕上所有对象
- R2 t( O( N; _( ~, c - S.Select acSelectionSetAll
6 G! M7 z* f0 q1 Z- A+ M: B - For Each T In S '遍历选择集
% h7 h$ K- x, b9 q5 J8 r - If T.Handle = "2D4EC" Then '找到指定的CAD表格时执行下面的代码。"2D4EC"是本文档中该表格的句柄 U; f/ s# E) C# L7 e5 D. @
- Set P = Object
8 q* W3 J9 B; M' n# s - T.SetText 1, 0, P.Coordinates(1) * 2 '在表格第二行(索引值1)第一列(索引值0)写入正方形边长。正方形边长为左上角Y坐标值乘以23 p9 Z' z% H: u! E( t# V: D! \
- Exit For '退出遍历循环7 W: e% S8 @2 U& r- |( d
- End If
9 p( z# G: ?7 R! U - Next7 }2 M3 I* D: j S
- S.Delete '删除用过的选择集% z. v+ }% Z/ V2 G8 ~: a8 }; A! K* G
- End If, @4 `. l# f& p2 C6 Q* C. a9 r0 x3 X
- End Sub
复制代码 6 L; s1 P1 u6 i4 h7 l
这个程序是简陋的,只有基本的功能,用于提示用VBA解决楼主问题的可行的途径。
: n; Y, J$ V, c* k: F程序中动态块与表格的关联关系是固定的,仅限于指定的文档中现存的对象。如果是编制一个实用程序,则代码中应该有设置关联关系的内容。另外,为了追求代码简单,程序中使用了文档层事件,这是一种低效率的做法,会明显影响到CAD的响应速度。6 r1 y+ s% w/ Q* ]( B& ~2 i0 F$ }
楼上在编辑动态块后表格不再响应,是因为对图形界面现有动态块参照的更新,实质上是CAD用新参照代替了旧的参照。也就是说,在更新块参照后,原先的、包含句柄为"2D67C"的正方形的动态块参照已被CAD删除了,而由CAD插入的新参照在图形界面缩放时,这个简陋的程序并不知道这个参照是用来代替原先的参照的,所以代码的核心部分并未被执行。 |
|