Hide Table of Contents

Get Preselected Object Example (VB.NET)

This example shows how to get a pre-selected object when a pre-selection event is fired.

'------------------------------------

' Preconditions:

' 1. Part, assembly, or drawing document

'    is active.

' 2. If a part or assembly document is active, then

'    pre-select (mouse over) a face.

'    - or -

'    If a drawing document is active, then pre-select

'    an edge.

' 3. Run the macro (press F5).

'

' NOTE: Tools > Options > Stop VSTA debugger on macro exit

'       must not be selected for this macro to run

'       to completion.  

'

' Postconditions:

' 1. Whenever a face is pre-selected in a part or assembly

'    document, statements confirming its pre-selection are

'    written to the Immediate window.

'    - or -

'    Whenever an edge is pre-selected in a drawing document,

'    statements confirming its pre-selection are written

'    to the Immediate window.

' 2. To stop running the macro, click Debug > Stop Debugging

'    in the Microsoft Visual Basic IDE.

'----------------------------------------

Imports SolidWorks.Interop.sldworks

Imports SolidWorks.Interop.swconst

Imports System

Imports System.Collections

Imports System.Diagnostics

 

Partial Class SolidWorksMacro

 

    Public WithEvents pDoc As PartDoc

    Public WithEvents aDoc As AssemblyDoc

    Public WithEvents dDoc As DrawingDoc

 

    Public Sub main()

 

        Dim swModel As ModelDoc2

        Dim openPart As Hashtable

        Dim openAssembly As Hashtable

        Dim openDrawing As Hashtable

 

        swModel = swApp.ActiveDoc

 

        ' Determine the document type

        ' and set up event handlers

        If swModel.GetType = swDocumentTypes_e.swDocPART Then

            pDoc = swModel

            openPart = New Hashtable

        ElseIf swModel.GetType = swDocumentTypes_e.swDocASSEMBLY Then

            aDoc = swModel

            openAssembly = New Hashtable

        ElseIf swModel.GetType = swDocumentTypes_e.swDocDRAWING Then

            dDoc = swModel

            openDrawing = New Hashtable

        End If

 

        AttachEventHandlers()

 

    End Sub

 

    Sub AttachEventHandlers()

        AttachSWEvents()

    End Sub

 

    Sub AttachSWEvents()

        If Not pDoc Is Nothing Then

            AddHandler pDoc.UserSelectionPreNotify, AddressOf Me.pDoc_UserSelectionPreNotify

        End If

        If Not aDoc Is Nothing Then

            AddHandler aDoc.UserSelectionPreNotify, AddressOf Me.aDoc_UserSelectionPreNotify

        End If

        If Not dDoc Is Nothing Then

            AddHandler dDoc.UserSelectionPreNotify, AddressOf Me.dDoc_UserSelectionPreNotify

        End If

    End Sub

 

    Private Function pDoc_UserSelectionPreNotify(ByVal SelectionType As Integer) As Integer

        If SelectionType = swSelectType_e.swSelFACES Then

            Dim swModel As ModelDoc2

            Dim swSelMgr As SelectionMgr

            Dim SelectedObject As Object

            Dim swFace As Face2

            Dim swFeature As Feature

            swModel = swApp.ActiveDoc

            swSelMgr = swModel.SelectionManager

            SelectedObject = swSelMgr.GetPreSelectedObject()

            If SelectionType = swSelectType_e.swSelFACES Then

                swFace = SelectedObject

                swFeature = swFace.GetFeature

                Debug.Print("Name of feature whose face you preselected: " & swFeature.Name)

                Debug.Print("   Mouse over a different face, or click Debug > Stop Debugging to stop running macro...")

                Debug.Print(" ")

            End If

        End If

    End Function

 

    Private Function aDoc_UserSelectionPreNotify(ByVal SelectionType As Integer) As Integer

        If SelectionType = swSelectType_e.swSelFACES Then

            Dim swModel As ModelDoc2

            Dim swSelMgr As SelectionMgr

            Dim SelectedObject As Object

            Dim swFace As Face2

            Dim swFeature As Feature

            swModel = swApp.ActiveDoc

            swSelMgr = swModel.SelectionManager

            SelectedObject = swSelMgr.GetPreSelectedObject()

            If SelectionType = swSelectType_e.swSelFACES Then

                swFace = SelectedObject

                swFeature = swFace.GetFeature

                Debug.Print("Name of feature whose face you preselected: " & swFeature.Name)

                Debug.Print("   Mouse over a different face, or click Debug > Stop Debugging to stop running macro...")

                Debug.Print(" ")

            End If

        End If

    End Function

 

    Private Function dDoc_UserSelectionPreNotify(ByVal SelectionType As Integer) As Integer

        If SelectionType = swSelectType_e.swSelEDGES Then

            Dim swModel As ModelDoc2

            Dim swSelMgr As SelectionMgr

            Dim SelectedObject As Object

            Dim swEdge As Edge

            Dim swBody As Body2

            swModel = swApp.ActiveDoc

            swSelMgr = swModel.SelectionManager

            SelectedObject = swSelMgr.GetPreSelectedObject()

            If SelectionType = swSelectType_e.swSelEDGES Then

                swEdge = SelectedObject

                swBody = swEdge.GetBody

                Debug.Print("Name of body whose edge you preselected: " & swBody.Name)

                Debug.Print("   Mouse over a different edge, or click Debug > Stop Debugging to stop running macro...")

                Debug.Print(" ")

            End If

        End If

    End Function

 

    ''' <summary>

    ''' The SldWorks swApp variable is pre-assigned for you.

    ''' </summary>

    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:   Get Preselected Object 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) 2013 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.