Hide Table of Contents

Get Features of Multibody Sheet Metal Part Example (VBA)

This example shows how to get the number and names of the features in a multibody sheet metal part.

' Preconditions: A multibody sheet metal part is open.
' Postconditions: Compare the results printed to the Immediate window with
' the bodies and features in the sheet metal solid bodies folder.

Option Explicit

Sub main()

    Dim swApp                       As SldWorks.SldWorks

    Dim swModel                     As SldWorks.ModelDoc2

    Dim swFeatMgr                   As SldWorks.FeatureManager

    Dim swFeat                      As SldWorks.Feature

    Dim swBodyFolder                As SldWorks.BodyFolder

    Dim swBody                      As Body2

    Dim FeatType                    As String

    Dim FeatTypeName                As String

    Dim NbrOfBodies                 As Long

    Dim Bodies                      As Variant

    Dim Features                    As Variant

    Dim i                           As Long

    Dim j                           As Long



    Set swApp = Application.SldWorks

    Set swModel = swApp.ActiveDoc

    Set swFeatMgr = swModel.FeatureManager


    Set swFeat = swModel.FirstFeature

    Do While Not swFeat Is Nothing

        FeatType = swFeat.Name

        FeatTypeName = swFeat.GetTypeName2


        Debug.Print "  " & FeatType & " [" & FeatTypeName & "]"

        If FeatTypeName = "SolidBodyFolder" Then

            Set swBodyFolder = swFeat.GetSpecificFeature2

            swBodyFolder.SetAutomaticCutList True
            swBodyFolder.SetAutomaticUpdate True

            Bodies = swBodyFolder.GetBodies

            Debug.Print "    Number of bodies: " & swBodyFolder.GetBodyCount
Debug.Print "    Cut list type: " & swBodyFolder.GetCutListType
Debug.Print "    Generate cut list automatically? " & swBodyFolder.GetAutomaticCutList
            Debug.Print "    Automatically update cut list? " & swBodyFolder.GetAutomaticUpdate

            For i = 0 To (swBodyFolder.GetBodyCount - 1)

                Set swBody = Bodies(i)

                Features = swBody.GetFeatures

                Debug.Print "    Number of features in body #" & i + 1 & ": " & swBody.GetFeatureCount

                For j = 0 To (swBody.GetFeatureCount - 1)

                    Debug.Print "       Name of feature: " & Features(j).GetTypeName2

                Next j

            Next i

        End If

        Set swFeat = swFeat.GetNextFeature



End Sub

Provide feedback on this topic

SOLIDWORKS welcomes your feedback concerning the presentation, accuracy, and thoroughness of the documentation. Use the form below to send your comments and suggestions about this topic directly to our documentation team. The documentation team cannot answer technical support questions. Click here for information about technical support.

* Required

Subject:   Feedback on Help Topics
Page:   Get Features of Multibody Sheet Metal Part Example (VBA)
*   I acknowledge I have read and I hereby accept the privacy policy under which my Personal Data will be used by Dassault Systèmes

Print Topic

Select the scope of content to print:


We have detected you are using a browser version older than Internet Explorer 7. For optimized display, we suggest upgrading your browser to Internet Explorer 7 or newer.

 Never show this message again

Web Help Content Version: API Help (English only) 2015 SP05

To disable Web help from within SOLIDWORKS and use local help instead, click Help > Use SOLIDWORKS Web Help.

To report problems encountered with the Web help interface and search, contact your local support representative. To provide feedback on individual help topics, use the “Feedback on this topic” link on the individual topic page.