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
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
|
// This file is generated by WOK (CPPExt).
// Please do not edit this file; modify original file instead.
// The copyright and license terms as defined for the original file apply to
// this header file considered to be the "object code" form of the original source.
#ifndef _BRepOffset_MakeOffset_HeaderFile
#define _BRepOffset_MakeOffset_HeaderFile
#ifndef _Standard_HeaderFile
#include <Standard.hxx>
#endif
#ifndef _Standard_Macro_HeaderFile
#include <Standard_Macro.hxx>
#endif
#ifndef _Standard_Real_HeaderFile
#include <Standard_Real.hxx>
#endif
#ifndef _TopoDS_Shape_HeaderFile
#include <TopoDS_Shape.hxx>
#endif
#ifndef _BRepOffset_Mode_HeaderFile
#include <BRepOffset_Mode.hxx>
#endif
#ifndef _Standard_Boolean_HeaderFile
#include <Standard_Boolean.hxx>
#endif
#ifndef _GeomAbs_JoinType_HeaderFile
#include <GeomAbs_JoinType.hxx>
#endif
#ifndef _TopTools_DataMapOfShapeReal_HeaderFile
#include <TopTools_DataMapOfShapeReal.hxx>
#endif
#ifndef _TopTools_MapOfShape_HeaderFile
#include <TopTools_MapOfShape.hxx>
#endif
#ifndef _BRepOffset_Analyse_HeaderFile
#include <BRepOffset_Analyse.hxx>
#endif
#ifndef _BRepAlgo_Image_HeaderFile
#include <BRepAlgo_Image.hxx>
#endif
#ifndef _TopTools_ListOfShape_HeaderFile
#include <TopTools_ListOfShape.hxx>
#endif
#ifndef _Handle_BRepAlgo_AsDes_HeaderFile
#include <Handle_BRepAlgo_AsDes.hxx>
#endif
#ifndef _BRepOffset_Error_HeaderFile
#include <BRepOffset_Error.hxx>
#endif
#ifndef _BRepOffset_MakeLoops_HeaderFile
#include <BRepOffset_MakeLoops.hxx>
#endif
class BRepAlgo_AsDes;
class TopoDS_Shape;
class TopoDS_Face;
class BRepOffset_Analyse;
class BRepAlgo_Image;
class TopTools_MapOfShape;
class BRepOffset_Inter3d;
class BRepOffset_DataMapOfShapeOffset;
class BRepOffset_MakeOffset {
public:
void* operator new(size_t,void* anAddress)
{
return anAddress;
}
void* operator new(size_t size)
{
return Standard::Allocate(size);
}
void operator delete(void *anAddress)
{
if (anAddress) Standard::Free((Standard_Address&)anAddress);
}
Standard_EXPORT BRepOffset_MakeOffset();
Standard_EXPORT BRepOffset_MakeOffset(const TopoDS_Shape& S,const Standard_Real Offset,const Standard_Real Tol,const BRepOffset_Mode Mode = BRepOffset_Skin,const Standard_Boolean Intersection = Standard_False,const Standard_Boolean SelfInter = Standard_False,const GeomAbs_JoinType Join = GeomAbs_Arc,const Standard_Boolean Thickening = Standard_False);
Standard_EXPORT void Initialize(const TopoDS_Shape& S,const Standard_Real Offset,const Standard_Real Tol,const BRepOffset_Mode Mode = BRepOffset_Skin,const Standard_Boolean Intersection = Standard_False,const Standard_Boolean SelfInter = Standard_False,const GeomAbs_JoinType Join = GeomAbs_Arc,const Standard_Boolean Thickening = Standard_False) ;
Standard_EXPORT void Clear() ;
//! Add Closing Faces, <F> has to be in the initial <br>
//! shape S. <br>
Standard_EXPORT void AddFace(const TopoDS_Face& F) ;
//! set the offset <Off> on the Face <F> <br>
Standard_EXPORT void SetOffsetOnFace(const TopoDS_Face& F,const Standard_Real Off) ;
Standard_EXPORT void MakeOffsetShape() ;
Standard_EXPORT void MakeThickSolid() ;
Standard_EXPORT const BRepOffset_Analyse& GetAnalyse() const;
Standard_EXPORT Standard_Boolean IsDone() const;
Standard_EXPORT const TopoDS_Shape& Shape() const;
//! returns information if IsDone() = FALSE. <br>
Standard_EXPORT BRepOffset_Error Error() const;
//! Returns <Image> containing links between initials <br>
//! shapes and offset faces. <br>
Standard_EXPORT const BRepAlgo_Image& OffsetFacesFromShapes() const;
//! Returns myJoin. <br>
Standard_EXPORT GeomAbs_JoinType GetJoinType() const;
//! Returns <Image> containing links between initials <br>
//! shapes and offset edges. <br>
Standard_EXPORT const BRepAlgo_Image& OffsetEdgesFromShapes() const;
//! Returns the list of closing faces stores by AddFace <br>
Standard_EXPORT const TopTools_MapOfShape& ClosingFaces() const;
protected:
private:
Standard_EXPORT void BuildOffsetByArc() ;
Standard_EXPORT void BuildOffsetByInter() ;
Standard_EXPORT void SelfInter(TopTools_MapOfShape& Modif) ;
Standard_EXPORT void Intersection3D(BRepOffset_Inter3d& Inter) ;
Standard_EXPORT void Intersection2D(const TopTools_MapOfShape& Modif,const TopTools_MapOfShape& NewEdges) ;
Standard_EXPORT void MakeLoops(TopTools_MapOfShape& Modif) ;
Standard_EXPORT void MakeLoopsOnContext(TopTools_MapOfShape& Modif) ;
Standard_EXPORT void MakeFaces(TopTools_MapOfShape& Modif) ;
Standard_EXPORT void MakeShells() ;
Standard_EXPORT void SelectShells() ;
Standard_EXPORT void EncodeRegularity() ;
Standard_EXPORT void MakeSolid() ;
Standard_EXPORT void ToContext(BRepOffset_DataMapOfShapeOffset& MapSF) ;
//! Private method use to update the map face<->offset <br>
Standard_EXPORT void UpdateFaceOffset() ;
//! Private method used to correct degenerated edges on conical faces <br>
Standard_EXPORT void CorrectConicalFaces() ;
//! Private method used to build walls for thickening the shell <br>
Standard_EXPORT void MakeMissingWalls() ;
Standard_Real myOffset;
Standard_Real myTol;
TopoDS_Shape myShape;
BRepOffset_Mode myMode;
Standard_Boolean myInter;
Standard_Boolean mySelfInter;
GeomAbs_JoinType myJoin;
Standard_Boolean myThickening;
TopTools_DataMapOfShapeReal myFaceOffset;
TopTools_MapOfShape myFaces;
BRepOffset_Analyse myAnalyse;
TopoDS_Shape myOffsetShape;
BRepAlgo_Image myInitOffsetFace;
BRepAlgo_Image myInitOffsetEdge;
BRepAlgo_Image myImageOffset;
TopTools_ListOfShape myWalls;
Handle_BRepAlgo_AsDes myAsDes;
Standard_Boolean myDone;
BRepOffset_Error myError;
BRepOffset_MakeLoops myMakeLoops;
};
// other Inline functions and methods (like "C++: function call" methods)
#endif
|