Hide Table of Contents

Get Centers of Mass in Drawing Views Example (VBA)

This example shows how to get the centers of mass in drawing views.

'----------------------------------------------------------------------
' Preconditions: Open a drawing that has one or more centers of mass.
'
' Postconditions: Inspect the Immediate window for the coordinates of
' all of the centers of mass in all of the views of the
' drawing.
'----------------------------------------------------------------------

Option Explicit

Dim swApp As SldWorks.SldWorks
Dim swModel As SldWorks.ModelDoc2
Dim swDrawDoc As SldWorks.DrawingDoc
Dim swView As SldWorks.View
Dim swCenterOfMass As SldWorks.CenterOfMass
Dim swAnnotation As SldWorks.Annotation
Dim sheetCount As Long
Dim viewCount As Long
Dim ss As Variant
Dim vv As Variant
Dim coord As Variant

Sub main()

    Set swApp = Application.SldWorks
    Set swModel = swApp.ActiveDoc
    Set swDrawDoc = swModel
    

    viewCount = swDrawDoc.GetViewCount
    ss = swDrawDoc.GetViews
   

    For sheetCount = LBound(ss) To UBound(ss)
        vv = ss(sheetCount)
        For viewCount = 1 To UBound(vv)
            Debug.Print (vv(viewCount).GetName2())
            Set swView = vv(viewCount)
            Set swCenterOfMass = swView.GetFirstCenterOfMass
            If Not swCenterOfMass Is Nothing Then
                Set swAnnotation = swCenterOfMass.GetAnnotation
                If Not swAnnotation Is Nothing Then
                    Debug.Print "  Annotation name: " & swAnnotation.GetName
                End If
                coord = swCenterOfMass.GetCoordinates
                Debug.Print "  Center of mass coordinates: X: " & coord(0) & ", Y: " & coord(1) & ", and Z: " & coord(2)
               

                While Not (swCenterOfMass.GetNext Is Nothing)
                    Set swCenterOfMass = swCenterOfMass.GetNext
                    If Not swCenterOfMass Is Nothing Then
                        Set swAnnotation = swCenterOfMass.GetAnnotation
                        If Not swAnnotation Is Nothing Then
                            Debug.Print "  Annotation name: " & swAnnotation.GetName
                        End If
                        coord = swCenterOfMass.GetCoordinates
                        Debug.Print "  Center of mass coordinates: X: " & coord(0) & ", Y: " & coord(1) & ", and Z: " & coord(2)
                    End If
                Wend
            End If
        Next viewCount
   

    Next sheetCount

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

 
*Email:  
Subject:   Feedback on Help Topics
Page:   Get Centers of Mass in Drawing Views Example (VBA)
*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.