它跟帮助例子中的这段代码:
Sub Ch4_CreateCompositeRegions() ' 创建两个圆,一个代表房间, ' 另一个代表房间中的柱子 Dim RoomObjects(0 To 1) As AcadCircle Dim center(0 To 2) As Double Dim radius As Double center(0) = 4 center(1) = 4 center(2) = 0 radius = 2# Set RoomObjects(0) = ThisDrawing.ModelSpace. _ AddCircle(center, radius) radius = 1# Set RoomObjects(1) = ThisDrawing.ModelSpace. _ AddCircle(center, radius) ' 从这两个圆创建一个面域 Dim regions As Variant regions = ThisDrawing.ModelSpace.AddRegion(RoomObjects) ' 将面域复制到面域变量中以便使用 Dim RoundRoomObj As AcadRegion Dim PillarObj As AcadRegion If regions(0).Area > regions(1).Area Then ' 第一个面域是房间 Set RoundRoomObj = regions(0) Set PillarObj = regions(1) Else ' 第一个面域是柱子 Set PillarObj = regions(0) Set RoundRoomObj = regions(1) End If ' 从地板空间减去柱子空间, ' 以获得表示地毯总面积的面域。 RoundRoomObj.Boolean acSubtraction, PillarObj ' 使用 Area 特性确定出地毯的总面积 MsgBox "The carpet area is: " & RoundRoomObj.Area End Sub 有很大的出入。我就不会用acSubtraction操作了。 |