Get Bodies in Components Example (VBA)
This example shows how to get the number of normal and user bodies in
the components in an assembly.
'-------------------------------------
' Preconditions:
' 1. Specified assembly document exists.
' 2. Run the macro.
'
' Postconditions: Each component's name, number of
' solid
bodies, body names, and body types are
' printed
to the Immediate window.
'
' To
understand the results of the macro:
' 1. Right-click filterholder in the
FeatureManager
' design
tree and click the Open Part button in
' the
context toolbar. Notice that there
' are
no screw holes in the part.
' 2. Close the part and examine the filterholder
' component,
which is the orange, flat, circular
' component
located on the front of the assembly
' in
the graphics area. There are screw
' holes
in the component.
' 3. Locate filterholder's information
in the
' Immediate
window. Because the component was
' modified
in the assembly, its body is identified
' as
a user body.
'
' NOTE: Because this assembly document is used by
' a
SolidWorks online tutorial, do not save
' any
changes when closing the document.
'--------------------------------------
Dim swApp As SldWorks.SldWorks
Dim swModel As ModelDoc2
Dim swAssembly As SldWorks.AssemblyDoc
Dim vComponents As Variant
Dim oneComponent As Component2
Dim vBodies As Variant
Dim vBodyInfo As Variant
Dim errors As Long, warnings As Long
Dim i As Long, j As Long
Sub main()
Set swApp = Application.SldWorks
' Open the assembly; substitute the name of your assembly
here
Set swModel = swApp.OpenDoc6("C:\Program
Files\SolidWorks Corp\SolidWorks\samples\tutorial\toolbox\lens_mount.sldasm",
swDocASSEMBLY, swOpenDocOptions_Silent, "", errors, warnings)
Set swAssembly = swModel
' Get the components in the assembly
vComponents = swAssembly.GetComponents(True)
For i = 0 To UBound(vComponents)
Set
oneComponent = vComponents(i)
Debug.Print
" "
Debug.Print
"Component name: " & oneComponent.Name2
'
Get the solid bodies in the component
vBodies
= oneComponent.GetBodies3(SwConst.swBodyType_e.swSolidBody,
vBodyInfo)
Debug.Print
" Number
of solid bodies: " & (UBound(vBodies) + 1)
For
j = 0 To UBound(vBodies)
Debug.Print
" Body
number: " & (j + 1)
Debug.Print
" Body
name: " & vBodies(j).Name
'
Print the type of body
Select
Case vBodyInfo(j)
Case
0
Debug.Print
" Body
type: user"
Case
1
Debug.Print
" Body
type: normal"
End
Select
Next
Next
End Sub