0024002: Overall code and build procedure refactoring -- automatic
[occt.git] / src / BRepOffset / BRepOffset_MakeOffset.hxx
1 // Created on: 1995-10-26
2 // Created by: Yves FRICAUD
3 // Copyright (c) 1995-1999 Matra Datavision
4 // Copyright (c) 1999-2014 OPEN CASCADE SAS
5 //
6 // This file is part of Open CASCADE Technology software library.
7 //
8 // This library is free software; you can redistribute it and/or modify it under
9 // the terms of the GNU Lesser General Public License version 2.1 as published
10 // by the Free Software Foundation, with special exception defined in the file
11 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
12 // distribution for complete text of the license and disclaimer of any warranty.
13 //
14 // Alternatively, this file may be used under the terms of Open CASCADE
15 // commercial license or contractual agreement.
16
17 #ifndef _BRepOffset_MakeOffset_HeaderFile
18 #define _BRepOffset_MakeOffset_HeaderFile
19
20 #include <Standard.hxx>
21 #include <Standard_DefineAlloc.hxx>
22 #include <Standard_Handle.hxx>
23
24 #include <Standard_Real.hxx>
25 #include <TopoDS_Shape.hxx>
26 #include <BRepOffset_Mode.hxx>
27 #include <Standard_Boolean.hxx>
28 #include <GeomAbs_JoinType.hxx>
29 #include <TopTools_DataMapOfShapeReal.hxx>
30 #include <TopTools_IndexedMapOfShape.hxx>
31 #include <BRepOffset_Analyse.hxx>
32 #include <BRepAlgo_Image.hxx>
33 #include <TopTools_ListOfShape.hxx>
34 #include <BRepOffset_Error.hxx>
35 #include <BRepOffset_MakeLoops.hxx>
36 #include <TopTools_MapOfShape.hxx>
37 #include <BRepOffset_DataMapOfShapeOffset.hxx>
38 class BRepAlgo_AsDes;
39 class TopoDS_Shape;
40 class TopoDS_Face;
41 class BRepOffset_Analyse;
42 class BRepAlgo_Image;
43 class BRepOffset_Inter3d;
44
45
46
47 class BRepOffset_MakeOffset 
48 {
49 public:
50
51   DEFINE_STANDARD_ALLOC
52
53   
54   Standard_EXPORT BRepOffset_MakeOffset();
55   
56   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);
57   
58   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);
59   
60   Standard_EXPORT void Clear();
61   
62   //! Add Closing Faces,  <F>  has to be  in  the initial
63   //! shape S.
64   Standard_EXPORT void AddFace (const TopoDS_Face& F);
65   
66   //! set the offset <Off> on the Face <F>
67   Standard_EXPORT void SetOffsetOnFace (const TopoDS_Face& F, const Standard_Real Off);
68   
69   Standard_EXPORT void MakeOffsetShape();
70   
71   Standard_EXPORT void MakeThickSolid();
72   
73   Standard_EXPORT const BRepOffset_Analyse& GetAnalyse() const;
74   
75   Standard_EXPORT Standard_Boolean IsDone() const;
76   
77   Standard_EXPORT const TopoDS_Shape& Shape() const;
78   
79   //! returns information if IsDone() = FALSE.
80   Standard_EXPORT BRepOffset_Error Error() const;
81   
82   //! Returns <Image> containing links between initials
83   //! shapes and offset faces.
84   Standard_EXPORT const BRepAlgo_Image& OffsetFacesFromShapes() const;
85   
86   //! Returns myJoin.
87   Standard_EXPORT GeomAbs_JoinType GetJoinType() const;
88   
89   //! Returns <Image> containing links between initials
90   //! shapes and offset edges.
91   Standard_EXPORT const BRepAlgo_Image& OffsetEdgesFromShapes() const;
92   
93   //! Returns the list of closing faces stores by AddFace
94   Standard_EXPORT const TopTools_IndexedMapOfShape& ClosingFaces() const;
95
96
97
98
99 protected:
100
101
102
103
104
105 private:
106
107   
108   Standard_EXPORT void BuildOffsetByArc();
109   
110   Standard_EXPORT void BuildOffsetByInter();
111   
112   Standard_EXPORT void SelfInter (TopTools_MapOfShape& Modif);
113   
114   Standard_EXPORT void Intersection3D (BRepOffset_Inter3d& Inter);
115   
116   Standard_EXPORT void Intersection2D (const TopTools_IndexedMapOfShape& Modif, const TopTools_IndexedMapOfShape& NewEdges);
117   
118   Standard_EXPORT void MakeLoops (TopTools_IndexedMapOfShape& Modif);
119   
120   Standard_EXPORT void MakeLoopsOnContext (TopTools_MapOfShape& Modif);
121   
122   Standard_EXPORT void MakeFaces (TopTools_IndexedMapOfShape& Modif);
123   
124   Standard_EXPORT void MakeShells();
125   
126   Standard_EXPORT void SelectShells();
127   
128   Standard_EXPORT void EncodeRegularity();
129   
130   Standard_EXPORT void MakeSolid();
131   
132   Standard_EXPORT void ToContext (BRepOffset_DataMapOfShapeOffset& MapSF);
133   
134   //! Private method use to update the map face<->offset
135   Standard_EXPORT void UpdateFaceOffset();
136   
137   //! Private method used to correct degenerated edges on conical faces
138   Standard_EXPORT void CorrectConicalFaces();
139   
140   //! Private method used to build walls for thickening the shell
141   Standard_EXPORT void MakeMissingWalls();
142
143
144   Standard_Real myOffset;
145   Standard_Real myTol;
146   TopoDS_Shape myShape;
147   BRepOffset_Mode myMode;
148   Standard_Boolean myInter;
149   Standard_Boolean mySelfInter;
150   GeomAbs_JoinType myJoin;
151   Standard_Boolean myThickening;
152   TopTools_DataMapOfShapeReal myFaceOffset;
153   TopTools_IndexedMapOfShape myFaces;
154   BRepOffset_Analyse myAnalyse;
155   TopoDS_Shape myOffsetShape;
156   BRepAlgo_Image myInitOffsetFace;
157   BRepAlgo_Image myInitOffsetEdge;
158   BRepAlgo_Image myImageOffset;
159   TopTools_ListOfShape myWalls;
160   Handle(BRepAlgo_AsDes) myAsDes;
161   Standard_Boolean myDone;
162   BRepOffset_Error myError;
163   BRepOffset_MakeLoops myMakeLoops;
164
165
166 };
167
168
169
170
171
172
173
174 #endif // _BRepOffset_MakeOffset_HeaderFile