Hide Table of Contents

Hide and Show All Edges in Drawing View (VBA)

This example shows how to hide and then show all of the edges in a drawing view.

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

' Preconditions: A drawing with a Drawing View1 exists.

'                Drawing View1 contains a model.

'

'

' Postconditions: All edges in Drawing View1 are hidden and then

'                shown.

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

Option Explicit

 

Dim swApp As SldWorks.SldWorks

Dim swModel As SldWorks.ModelDoc2

Dim swDraw As SldWorks.DrawingDoc

Dim swDocSpecification As SldWorks.DocumentSpecification

Dim swSheet As SldWorks.Sheet

Dim swView As SldWorks.View

Dim swDrawingComponent As SldWorks.DrawingComponent

Dim swComponent As SldWorks.Component2

Dim swEntity As SldWorks.Entity

Dim vEdges As Variant

Dim bRet As Boolean

Dim i As Long

 

Sub main()

 

Set swApp = Application.SldWorks

 

' Open the drawing document; replace

' c:\test\knob.SLDDRW with the path

' and name of your drawing

Set swDocSpecification = swApp.GetOpenDocSpec("C:\test\knob.SLDDRW")

Set swModel = swApp.ActiveDoc

If swModel Is Nothing Then

    Set swModel = swApp.OpenDoc7(swDocSpecification)

End If

 

Set swApp = Application.SldWorks

Set swModel = swApp.ActiveDoc

Set swDraw = swModel

 

' Get the current sheet

Set swSheet = swDraw.GetCurrentSheet

Debug.Print swSheet.GetName

 

' Select Drawing View1

bRet = swModel.Extension.SelectByID2("Drawing View1", "DRAWINGVIEW", 0#, 0#, 0#, True, 0, Nothing, swSelectOptionDefault): Debug.Assert bRet

Set swView = swModel.SelectionManager.GetSelectedObject6(1, -1)

 

' Print the drawing view name and get the component in the drawing view

Debug.Print swView.GetName2

Set swDrawingComponent = swView.RootDrawingComponent

Set swComponent = swDrawingComponent.Component

 

' Get the component's visible entities in the drawing view

Dim eCount As Long

eCount = swView.GetVisibleEntityCount(swComponent, swViewEntityType_Edge)

vEdges = swView.GetVisibleEntities(swComponent, swViewEntityType_Edge)

Debug.Print "Number of edges found: " & eCount

 

' Hide all of the visible edges in the drawing view

For i = 0 To eCount - 1

    Set swEntity = vEdges(i)

    swEntity.Select4 True, Nothing

    swDraw.HideEdge

    Next i

 

' Clear all selections

swModel.ClearSelection2 True

 

' Show all hidden edges

swView.HiddenEdges = vEdges

 

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:   Hide and Show All Edges in Drawing View (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) 2012 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.