Hide Table of Contents

Save Solid Body to File Example (VB.NET)

This example shows how to save a weldment member to another part document.

'----------------------------------------------------------------------------
' Preconditions: Open public_documents\samples\tutorial\api\weldment_box3.sldprt.
'
' Postconditions:
' 1. Updates the cut list in the weldment part.
' 2. Saves the first weldment member in the FeatureManager design tree to
'    RefWeldment1.sldprt, and saves the cut list properties in the parent part
'    to the cut list of the new part.
' 3. Opens RefWeldment1.sldprt and updates its cut list. (This step could
'    take a few minutes to complete.)
' 4. At Stop, press F5.
' 5. Closes RefWeldment1.sldprt.
' 6. To verify steps 2 and 3, open and inspect RefWeldment1.sldprt, which resides
'    in the same folder as this macro.
'
' NOTE: Because weldment_box3.sldprt is used elsewhere, do not save changes.
'---------------------------------------------------------------------------

Imports SolidWorks.Interop.sldworks
Imports SolidWorks.Interop.swconst
Imports System.Runtime.InteropServices
Imports System

Partial Class SolidWorksMacro

    
Dim swFeat As Feature
    
Dim swBodyFolder As BodyFolder
    
Dim updateBoolstatus As Boolean
    Dim boolstatus As Boolean
    Dim longstatus As Integer
    Dim longWarnings As Integer
    Dim currentModel As ModelDoc2
    
Dim swModel As ModelDoc2
    
Dim modelType As Integer
    Dim modelTitle As String

    
Sub main()

        currentModel = swApp.ActiveDoc

        modelTitle = currentModel.GetTitle
        modelType = currentModel.GetType

        swFeat = currentModel.FirstFeature
        
If swFeat Is Nothing Then ErrorMsg(swApp, "Failed to get first feature")

        
Do While Not swFeat Is Nothing
            If swFeat.GetTypeName2 = "SolidBodyFolder" Then
                swBodyFolder = swFeat.GetSpecificFeature2
                
If swBodyFolder Is Nothing Then ErrorMsg(swApp, "Failed to get body folder")

                boolstatus = swBodyFolder.SetAutomaticCutList(
True)

                boolstatus = swBodyFolder.UpdateCutList()

                
Exit Do
            End If
            swFeat = swFeat.GetNextFeature
        
Loop

        updateBoolstatus = False

        swFeat = currentModel.FirstFeature
        
If swFeat Is Nothing Then ErrorMsg(swApp, "Failed to get first feature")

        
Do While Not swFeat Is Nothing
            If swFeat.GetTypeName2 = "WeldMemberFeat" Then
                boolstatus = swFeat.Select2(False, 0)
                
If boolstatus = False Then ErrorMsg(swApp, "Failed to select feature")

                
' Save the selected solid body weldment member to another part,
                ' transferring the solid body's cut list properties to the new part's cut list;
                ' automatically creates a weldment and cut list folder
                boolstatus = currentModel.SaveToFile3(swApp.GetCurrentMacroPathFolder + "\RefWeldment1" + ".sldprt", 1, swCutListTransferOptions_e.swCutListTransferOptions_CutListProperties, False, "", longstatus, longWarnings)

                
Stop

                If boolstatus = False Then ErrorMsg(swApp, "Failed to insert weldment member into new part")

                swModel = swApp.ActiveDoc
                
If swModel Is Nothing Then ErrorMsg(swApp, "Failed to set open model as active document")

                updateBoolstatus =
True
                Exit Do
            End If
            swFeat = swFeat.GetNextFeature
        
Loop

        If updateBoolstatus = True Then
            swFeat = currentModel.FirstFeature
            
If swFeat Is Nothing Then ErrorMsg(swApp, "Failed to get first feature")

            
Do While Not swFeat Is Nothing
                If swFeat.GetTypeName2 = "SolidBodyFolder" Then
                    swBodyFolder = swFeat.GetSpecificFeature2
                    
If swBodyFolder Is Nothing Then ErrorMsg(swApp, "Failed to get body folder")

                    boolstatus = swBodyFolder.SetAutomaticCutList(
True)
                    
If boolstatus = False Then ErrorMsg(swApp, "Failed to set cut list to automatic")

                    boolstatus = swBodyFolder.UpdateCutList()
                    
If boolstatus = False Then ErrorMsg(swApp, "Failed to update cut list")

                    swApp.CloseDoc(swModel.GetTitle)
                    
Exit Do
                End If
                swFeat = swFeat.GetNextFeature
            
Loop
        End If

    End Sub

    Sub ErrorMsg(ByVal Swapp As Object, ByVal Message As String)
        Swapp.SendMsgToUser2(Message, 0, 0)
        Swapp.RecordLine(
"'*** WARNING - General")
        Swapp.RecordLine(
"'*** " & Message)
        Swapp.RecordLine(
"")
    
End Sub


    Public swApp As SldWorks


End Class
 

 

 



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

 
*Email:  
Subject:   Feedback on Help Topics
Page:   Save Solid Body to File Example (VB.NET)
*Comment:  
*   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:

x

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
x

Web Help Content Version: API Help (English only) 2019 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.