概要 - ブロック参照を分解する(VBA/ActiveX)

Explode メソッドを使用して、ブロック参照を分解します。

ブロック参照を分解することにより、ブロックを修正したり、ブロックを構成するオブジェクトを追加または削除することができます。

分解されたブロック参照の結果を表示する

次の例では、ブロックを定義し、その定義に円を追加します。次に、ブロック参照としてブロックを図面に挿入します。次に、ブロック参照を分解し、その結果のオブジェクトをタイプとともに表示します。

Sub Ch10_ExplodingABlock()
 ' Define the block
 Dim blockObj As AcadBlock
 Dim insertionPnt(0 To 2) As Double
 insertionPnt(0) = 0
 insertionPnt(1) = 0
 insertionPnt(2) = 0
 Set blockObj = ThisDrawing.Blocks.Add _
 (insertionPnt, "CircleBlock")
 
 ' Add a circle to the block
 Dim circleObj As AcadCircle
 Dim center(0 To 2) As Double
 Dim radius As Double
 center(0) = 0
 center(1) = 0
 center(2) = 0
 radius = 1
 Set circleObj = blockObj.AddCircle(center, radius)
 
 ' Insert the block
 Dim blockRefObj As AcadBlockReference
 insertionPnt(0) = 2
 insertionPnt(1) = 2
 insertionPnt(2) = 0
 Set blockRefObj = ThisDrawing.ModelSpace.InsertBlock _
 (insertionPnt, "CircleBlock", 1#, 1#, 1#, 0)
 ZoomAll
 MsgBox "The circle belongs to " & blockRefObj.ObjectName
 
 ' Explode the block reference
 Dim explodedObjects As Variant
 explodedObjects = blockRefObj.Explode
 
 ' Loop through the exploded objects
 Dim I As Integer
 For I = 0 To UBound(explodedObjects)
 explodedObjects(I).Color = acRed
 explodedObjects(I).Update
 MsgBox "Exploded Object " & I & ": " _
 & explodedObjects(I).ObjectName
 explodedObjects(I).Color = acByLayer
 explodedObjects(I).Update
 Next
End Sub