summaryrefslogtreecommitdiff
path: root/inc/BRepOffset_MakeOffset.hxx
blob: b112fa4d791f47dba39e0a8c8a37b52bfc4a0270 (plain)
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