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
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
|
-- File: TopOpeBRepBuild_Tools.cdl
-- Created: Tue Nov 2 15:21:24 1999
-- Author: Peter KURNEV
-- <pkv@irinox.nnov.matra-dtv.fr>
---Copyright: Matra Datavision 1999
class Tools from TopOpeBRepBuild
---Purpose: Auxiliary methods used in TopOpeBRepBuild_Builder1 class
uses
Shape from TopoDS,
Face from TopoDS,
Wire from TopoDS,
Edge from TopoDS,
Vec from gp,
State from TopAbs,
ShapeEnum from TopAbs,
IndexedDataMapOfShapeListOfShape from TopTools,
IndexedMapOfShape from TopTools,
MapOfShape from TopTools,
DataMapOfShapeState from TopOpeBRepDS,
IndexedDataMapOfShapeWithState from TopOpeBRepDS,
IndexedMapOfOrientedShape from TopTools,
IndexedDataMapOfShapeShape from TopTools,
ShapeClassifier from TopOpeBRepTool
is
DumpMapOfShapeWithState (myclass;
iP:Integer from Standard;
aMapOfShapeWithState: IndexedDataMapOfShapeWithState from TopOpeBRepDS);
FindState (myclass;
aVertex: Shape from TopoDS;
aState : State from TopAbs;
aShapeEnum:ShapeEnum from TopAbs;
aMapVertexEdges:IndexedDataMapOfShapeListOfShape from TopTools;
aMapProcessedVertices:out MapOfShape from TopTools;
aMapVs:out DataMapOfShapeState from TopOpeBRepDS);
PropagateState (myclass;
aSplEdgesState:DataMapOfShapeState from TopOpeBRepDS;
anEdgesToRestMap:IndexedMapOfShape from TopTools;
aShapeEnum1:ShapeEnum from TopAbs;
aShapeEnum2:ShapeEnum from TopAbs;
aShapeClassifier:in out ShapeClassifier from TopOpeBRepTool;
aMapOfShapeWithState:out IndexedDataMapOfShapeWithState from TopOpeBRepDS;
anUnkStateShapes:MapOfShape from TopTools);
FindStateThroughVertex (myclass;
aShape :Shape from TopoDS;
aShapeClassifier:in out ShapeClassifier from TopOpeBRepTool;
aMapOfShapeWithState:out IndexedDataMapOfShapeWithState from TopOpeBRepDS;
anAvoidSubshMap: MapOfShape from TopTools)
returns State from TopAbs;
PropagateStateForWires (myclass;
aFacesToRestMap:IndexedMapOfShape from TopTools;
aMapOfShapeWithState:out IndexedDataMapOfShapeWithState from TopOpeBRepDS);
SpreadStateToChild (myclass;
aShape:Shape from TopoDS;
aState:State from TopAbs;
aMapOfShapeWithState:out IndexedDataMapOfShapeWithState from TopOpeBRepDS);
FindState1 (myclass;
anEdge:Shape from TopoDS;
aState:State from TopAbs;
aMapEdgesFaces:IndexedDataMapOfShapeListOfShape from TopTools;
aMapProcessedVertices:out MapOfShape from TopTools;
aMapVs:out DataMapOfShapeState from TopOpeBRepDS);
FindState2 (myclass;
anEdge:Shape from TopoDS;
aState:State from TopAbs;
aMapEdgesFaces:IndexedDataMapOfShapeListOfShape from TopTools;
aMapProcessedEdges:out MapOfShape from TopTools;
aMapVs:out DataMapOfShapeState from TopOpeBRepDS);
GetAdjacentFace (myclass;
aFaceObj:Shape from TopoDS;
anEObj :Shape from TopoDS;
anEdgeFaceMap:IndexedDataMapOfShapeListOfShape from TopTools;
anAdjFaceObj :out Shape from TopoDS)
returns Boolean from Standard;
GetNormalToFaceOnEdge (myclass;
aFObj :Face from TopoDS;
anEdgeObj:Edge from TopoDS;
aDirNormal:out Vec from gp);
GetNormalInNearestPoint(myclass; aFace : Face from TopoDS;
anEdge : Edge from TopoDS;
aNormal: out Vec from gp);
---Purpose: This function used to compute normal in point which is located
--- near the point with param UV (used for computation of normals where the normal in the point UV equal to zero).
GetTangentToEdgeEdge (myclass;
aFObj :Face from TopoDS;
anEdgeObj:Edge from TopoDS;
aOriEObj :Edge from TopoDS;
aTangent :out Vec from gp)
returns Boolean from Standard;
GetTangentToEdge (myclass;
anEdgeObj:Edge from TopoDS;
aTangent:out Vec from gp)
returns Boolean from Standard;
UpdatePCurves (myclass;
aWire : Wire from TopoDS;
fromFace : Face from TopoDS;
toFace : Face from TopoDS);
---Purpose : Recompute PCurves of the all edges from the wire on the <toFace>
UpdateEdgeOnPeriodicalFace(myclass;
aEdgeToUpdate : Edge from TopoDS;
OldFace : Face from TopoDS;
NewFace : Face from TopoDS);
---Purpose : recompute PCurves of the closing (SIM , with 2 PCurves) edge on the NewFace
UpdateEdgeOnFace(myclass;
aEdgeToUpdate : Edge from TopoDS;
OldFace : Face from TopoDS;
NewFace : Face from TopoDS);
---Purpose : recompute PCurve of the edge on the NewFace
IsDegEdgesTheSame (myclass;
anE1: Shape from TopoDS;
anE2: Shape from TopoDS)
returns Boolean from Standard;
NormalizeFace(myclass; oldFace : Shape from TopoDS;
corrFace : out Shape from TopoDS);
---Purpose : test if <oldFace> does not contain INTERNAL or EXTERNAL edges
--- and remove such edges in case of its presence. The result is stored in <corrFace>
CorrectFace2d(myclass; oldFace : Shape from TopoDS;
corrFace : out Shape from TopoDS;
aSourceShapes: IndexedMapOfOrientedShape from TopTools;
aMapOfCorrect2dEdges:out IndexedDataMapOfShapeShape from TopTools);
---Purpose: test if UV representation of <oldFace> is good (i.e. face is closed in 2d).
-- if face is not closed , this method will try to close such face and will
-- return corrected edges in the <aMapOfCorrect2dEdges>. Parameter <aSourceShapes>
-- used to fix the edge (or wires) which should be correct (Corrector used it as a start shapes).
-- NOTE : Parameter corrFace doesn't mean anything. If you want to use this method , rebuild resulting face
-- after by yourself using corrected edges.
--modified by NIZNHY-PKV Fri Feb 11 17:20:08 2000 from
------------------------------------------------------------
-- Tools to correct tolerances Fri Feb 11 17:20:08 NIZNHY-PKV
CorrectTolerances (myclass;
aS: Shape from TopoDS;
aTolMax: Real from Standard =0.0001);
CorrectCurveOnSurface (myclass;
aS: Shape from TopoDS;
aTolMax: Real from Standard =0.0001);
CorrectPointOnCurve (myclass;
aS: Shape from TopoDS;
aTolMax: Real from Standard =0.0001);
--modified by NIZNHY-PKV Fri Feb 11 17:20:20 2000 to
CheckFaceClosed2d (myclass;
theFace: Face from TopoDS)
returns Boolean from Standard;
---Purpose: Checks if <theFace> has the properly closed in 2D boundary(ies)
end Tools;
|