-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy path遍历工程图引出文本并修改其显示格式.txt
143 lines (107 loc) · 4.79 KB
/
遍历工程图引出文本并修改其显示格式.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
Sub ModifyTolerances()
CATIA.DisplayFileAlerts = False
'---------------------------------------------------------------------------
'1/ Read active CATDrawing Document
'---------------------------------------------------------------------------
Dim DrwDoc As DrawingDocument
Set DrwDoc = CATIA.ActiveDocument
' Get Selection Object and clear it
Dim DrwSelect As Selection
Set DrwSelect = DrwDoc.Selection
' Variables declaration
Dim ElemDispatch As CATBaseDispatch
Dim NomObj As String
Dim numsheet As Long
Dim numview As Long
Dim numtxt As Long
Dim numleader As Long
'---------------------------------------------------------------------------
'2/ Scan all the sheet of the current drawing (Included detail sheet)
'---------------------------------------------------------------------------
Dim DrwSheets As DrawingSheets
Set DrwSheets = DrwDoc.Sheets
Dim CurrentSheet As DrawingSheet
'Read the current sheet to restore it at the end of the macro
Dim SheetToRestore As DrawingSheet
Set SheetToRestore = DrwSheets.ActiveSheet
For numsheet = 1 To DrwSheets.count
Set CurrentSheet = DrwSheets.Item(numsheet)
' Active Currentsheet
CurrentSheet.Activate
' Clear the selection
DrwSelect.Clear
Dim DrwViews As DrawingViews
Set DrwViews = CurrentSheet.Views
'Read the current view to restore it at the end of the macro
Dim ViewToRestore As DrawingView
Set ViewToRestore = DrwViews.ActiveView
'---------------------------------------------------------------------------
'3/ Scan all the view of the current sheet
'---------------------------------------------------------------------------
Dim CurrentView As DrawingView
For numview = 1 To DrwViews.count
Set CurrentView = DrwViews.Item(numview)
'Active the current view
CurrentView.Activate
'---------------------------------------------------------------------------
'4/ Scan all the texts of the current view
'---------------------------------------------------------------------------
Dim Texts As DrawingTexts
Set Texts = CurrentView.Texts
For numtxt = 1 To Texts.count
Dim CurrentText As DrawingText
Set CurrentText = Texts.Item(numtxt)
'---------------------------------------------------------------------------
'5/ Scan all the leaders of the current text
'---------------------------------------------------------------------------
Dim Leaders As DrawingLeaders
Set Leaders = CurrentText.Leaders
For numleader = 1 To Leaders.count
Dim CurrentLeader As DrawingLeader
Set CurrentLeader = Leaders.Item(numleader)
' Manage error on HeadTarget method when
' no element is pointed by the text leader.
On Error Resume Next
' Get object pointed on the leader
Set ElemDispatch = Nothing
Set ElemDispatch = CurrentLeader.HeadTarget
NomObj = TypeName(ElemDispatch)
'------------------------------------------------------------------------------
'6/ Check tolerances and the frame type of the dimension pointed by text leader
'------------------------------------------------------------------------------
' A dimension is pointed by text leader
' If NomObj = "DrawingDimension" Then
' Get the dimension object
Dim PointedDim As DrawingDimension
Set PointedDim = ElemDispatch
' Read dimension tolerances
Dim oTolType As Long
Dim oDisplayMode As Long
Dim oTolName As String
Dim oUpTolS As String
Dim oLowTolS As String
Dim oUpTolD As Double
Dim oLowTolD As Double
PointedDim.GetTolerances oTolType, oTolName, oUpTolS, oLowTolS, oUpTolD, oLowTolD, oDisplayMode
' Read dimension frame type
Dim TypeFrame As CatDimFrame
TypeFrame = PointedDim.ValueFrame
'---------------------------------------------------------------------------
'7/ Change the visualization of the text leader linked to that dimension
'---------------------------------------------------------------------------
' If dimension does not respect the criteria text leader object is highlighted
If oTolType <> 0 Or TypeFrame <> catFraRectangle Then
DrwSelect.Add CurrentText
DrwSelect.VisProperties.SetRealColor 50, 150, 255, 1
DrwSelect.VisProperties.SetRealWidth 2, 1
End If
' End If
Next
Next
'Restore the view
ViewToRestore.Activate
Next
Next
'Restore the Drawing Document sheet
SheetToRestore.Activate
End Sub