Get Shut-Off Surface Data Example (VBA)
This example shows how to get a shut-off surface feature's data.
 
'-----------------------------------------------------
'
' Preconditions: Model document is open and contains a 
 Shut-Off Surface1 feature.
'
' Postconditions: None
'
'-----------------------------------------------------
Option Explicit
 
Dim swApp As SldWorks.SldWorks
Dim swModel As SldWorks.ModelDoc2
Dim swModelDocExt As SldWorks.ModelDocExtension
Dim swSelMgr As SldWorks.SelectionMgr
Dim swFeat As SldWorks.Feature
Dim swFeatData As SldWorks.ShutOffSurfaceFeatureData
Dim swEnt As SldWorks.entity
Dim params As Variant
Dim boolstatus As Boolean
Dim i As Integer
Dim j As Integer
 
Sub main()
Set swApp = Application.SldWorks
Set swModel = swApp.ActiveDoc
Set swModelDocExt = swModel.Extension
Set swSelMgr = swModel.SelectionManager
boolstatus = swModelDocExt.SelectByID2("Shut-Off 
 Surface1", "REFSURFACE", 0, 0, 0, False, 0, Nothing, swSelectOptionDefault)
Set swFeat = swSelMgr.GetSelectedObject5(1)
Set swFeatData = swFeat.GetDefinition
boolstatus = swFeatData.AccessSelections(swModel, 
 Nothing)
Debug.Print "Status = " + CStr(swFeatData.status)
Debug.Print "Knit flag = " + CStr(swFeatData.knit)
Debug.Print "Edge count = " + CStr(swFeatData.GetEdgeCount)
Debug.Print "Loop count = " + CStr(swFeatData.GetLoopCount)
For i = 0 To swFeatData.GetLoopCount 
 - 1
    Debug.Print 
 "Loop(" + CStr(i) + ")"
    Debug.Print 
 "    Edge 
 count = " + CStr(swFeatData.GetLoopEdgeCount(i))
    Debug.Print 
 "    Patch 
 type = " + CStr(swFeatData.LoopPatchType(i))
    params 
 = swFeatData.LoopEdges(i)
    For 
 j = 0 To UBound(params)
        Set 
 swEnt = params(j)
        boolstatus 
 = swEnt.Select4(False, Nothing)
    Next 
 j
Next i
params = swFeatData.Edges
For i = 0 To UBound(params)
    Set 
 swEnt = params(i)
    boolstatus 
 = swEnt.Select4(False, Nothing)
    
    Set 
 swEnt = swFeatData.GetFaceTangentTo(i)
    If 
 Not swEnt Is Nothing Then
        boolstatus 
 = swEnt.Select4(True, Nothing)
    End 
 If
    swFeatData.FlipFaceTangentTo (i)
    Set 
 swEnt = swFeatData.GetFaceTangentTo(i)
    If 
 Not swEnt Is Nothing Then
        boolstatus 
 = swEnt.Select4(True, Nothing)
    End 
 If
    swFeatData.FlipFaceTangentTo (i)
Next i
boolstatus = swFeat.ModifyDefinition(swFeatData, swModel, 
 Nothing)
End Sub