|
|
回复 #7 truezx 的帖子
下面是附件中的代码
! u {: p) Y& a8 t- Private Sub AcadDocument_ObjectModified(ByVal Object As Object) '在thisdrawing对象的代码模块声明一个事件过程,当文档被修改时执行其中的代码/ `' L$ j0 p. q
- Dim S As AcadSelectionSet, T As Object, P As AcadLWPolyline
. P- i1 J* f7 w; o - If Object.Handle = "2D67C" Then '当被修改的对象为指定的动态块中的正方形时执行下面的代码。"2D67C"是本文档中该正方形的句柄
+ Q( @( g+ _ W o. w6 o/ w/ t/ [ - Set S = ThisDrawing.SelectionSets.Add("SS") '新建选择集并选择屏幕上所有对象1 u5 y. B2 S4 {
- S.Select acSelectionSetAll
% m- d7 Q& O0 ]; h( w, s - For Each T In S '遍历选择集0 R3 R6 G' h- k2 [3 \
- If T.Handle = "2D4EC" Then '找到指定的CAD表格时执行下面的代码。"2D4EC"是本文档中该表格的句柄
! @) Y; `9 j' \) k' Q+ c( N - Set P = Object
% |. l( k. E8 ]. c& a' J v5 ]! e, Q - T.SetText 1, 0, P.Coordinates(1) * 2 '在表格第二行(索引值1)第一列(索引值0)写入正方形边长。正方形边长为左上角Y坐标值乘以2
0 R2 v4 t+ A- F) T' N - Exit For '退出遍历循环( T! c: h3 e) {9 K+ L0 p1 w
- End If/ Y% h# f" U# J& S9 T
- Next
* e3 ?) q9 r# c: f - S.Delete '删除用过的选择集& M \* x9 }6 |0 N& |. g2 e1 ~
- End If
( X4 g1 g8 v# Q4 e% L - End Sub
复制代码
3 _6 U4 l* o+ W& Q6 P1 Q7 _( ]& K这个程序是简陋的,只有基本的功能,用于提示用VBA解决楼主问题的可行的途径。/ f0 p0 o3 R9 f- w: b
程序中动态块与表格的关联关系是固定的,仅限于指定的文档中现存的对象。如果是编制一个实用程序,则代码中应该有设置关联关系的内容。另外,为了追求代码简单,程序中使用了文档层事件,这是一种低效率的做法,会明显影响到CAD的响应速度。* u" P1 X+ @& L2 I- }4 J4 q6 A6 C
楼上在编辑动态块后表格不再响应,是因为对图形界面现有动态块参照的更新,实质上是CAD用新参照代替了旧的参照。也就是说,在更新块参照后,原先的、包含句柄为"2D67C"的正方形的动态块参照已被CAD删除了,而由CAD插入的新参照在图形界面缩放时,这个简陋的程序并不知道这个参照是用来代替原先的参照的,所以代码的核心部分并未被执行。 |
|