1 // Copyright (C) 2007-2024 CEA, EDF, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License, or (at your option) any later version.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
23 // File: GEOMAlgo_Gluer2_1.cxx
24 // Author: Peter KURNEV
26 #include <GEOMAlgo_Gluer2.hxx>
31 #include <TopLoc_Location.hxx>
33 #include <Geom_Surface.hxx>
35 #include <TopAbs_ShapeEnum.hxx>
37 #include <TopoDS_Shape.hxx>
38 #include <TopoDS_Vertex.hxx>
39 #include <TopoDS_Edge.hxx>
40 #include <TopoDS_Wire.hxx>
41 #include <TopoDS_Face.hxx>
42 #include <TopoDS_Iterator.hxx>
44 #include <BRep_Tool.hxx>
45 #include <BRep_Builder.hxx>
47 #include <BRepTools.hxx>
50 #include <TopTools_MapOfShape.hxx>
51 #include <TopTools_ListIteratorOfListOfShape.hxx>
52 #include <TopTools_ListOfShape.hxx>
54 #include <BOPTools_AlgoTools.hxx>
55 #include <GEOMAlgo_AlgoTools.hxx>
56 #include <BOPTools_AlgoTools2D.hxx>
58 //=======================================================================
59 //function : MakeBRepShapes
61 //=======================================================================
62 void GEOMAlgo_Gluer2::MakeBRepShapes(const TopoDS_Shape& theS,
63 TopoDS_Shape& theSnew)
65 TopAbs_ShapeEnum aType;
67 aType=theS.ShapeType();
68 if (aType==TopAbs_EDGE) {
69 TopoDS_Edge aEE, aEEnew;
71 aEE=*((TopoDS_Edge*)&theS);
72 MakeEdge(aEE, aEEnew);
79 else if (aType==TopAbs_FACE) {
80 TopoDS_Face aFF, aFFnew;
82 aFF=*((TopoDS_Face*)&theS);
83 MakeFace(aFF, aFFnew);
91 //=======================================================================
94 //=======================================================================
95 void GEOMAlgo_Gluer2::MakeFace(const TopoDS_Face& theF,
98 Standard_Boolean bIsToReverse, bIsUPeriodic;
99 Standard_Integer iRet;
100 Standard_Real aTol, aUMin, aUMax, aVMin, aVMax;
101 Handle(Geom_Surface) aS;
102 TopLoc_Location aLoc;
103 TopoDS_Shape aW, aWr;
105 TopoDS_Face aFF, aFnew;
106 TopoDS_Iterator aItW, aItE;
108 TopTools_ListOfShape aLEr;
109 TopTools_ListIteratorOfListOfShape aItLE;
114 aFF.Orientation(TopAbs_FORWARD);
116 aTol=BRep_Tool::Tolerance(aFF);
117 aS=BRep_Tool::Surface(aFF, aLoc);
118 bIsUPeriodic=GEOMAlgo_AlgoTools::IsUPeriodic(aS);
119 BRepTools::UVBounds(aFF, aUMin, aUMax, aVMin, aVMax);
121 aBB.MakeFace (aFnew, aS, aLoc, aTol);
123 aItW.Initialize(aFF);
124 for (; aItW.More(); aItW.Next()) {
125 const TopoDS_Shape& aW=aItW.Value();
127 if (!myOrigins.IsBound(aW)) {
132 aWr=myOrigins.Find(aW);
134 // clear contents of Wr
136 aItE.Initialize(aWr);
137 for (; aItE.More(); aItE.Next()) {
138 const TopoDS_Shape& aEr=aItE.Value();
142 aItLE.Initialize(aLEr);
143 for (; aItLE.More(); aItLE.Next()) {
144 const TopoDS_Shape& aEr=aItLE.Value();
145 aBB.Remove(aWr, aEr);
148 // refill contents of Wr
150 for (; aItE.More(); aItE.Next()) {
151 const TopoDS_Edge& aE=*((TopoDS_Edge*)(&aItE.Value()));
154 if (myOrigins.IsBound(aE)) {
155 aEx=*((TopoDS_Edge*)(&myOrigins.Find(aE)));
158 if (!BRep_Tool::Degenerated(aEx)) {
159 aEx.Orientation(TopAbs_FORWARD);
160 TopoDS_Edge aE_forward = aE;
161 aE_forward.Orientation(TopAbs_FORWARD);
163 GEOMAlgo_AlgoTools::RefinePCurveForEdgeOnFace(aEx, aFF, aUMin, aUMax);
166 //modified by NIZNHY-PKV Fri Feb 03 11:18:17 2012f
167 iRet=GEOMAlgo_AlgoTools::BuildPCurveForEdgeOnFace(aE_forward, aEx, aFF, myContext);
171 //modified by NIZNHY-PKV Fri Feb 03 11:18:20 2012t
173 bIsToReverse=GEOMAlgo_AlgoTools::IsSplitToReverse(aEx, aE_forward, myContext);
174 //bIsToReverse=BOPTools_AlgoTools::IsSplitToReverse(aEx, aE, myContext);
176 aEx.Orientation(aE.Orientation());
182 aEx.Orientation(aE.Orientation());
185 }// for (; aItE.More(); aItE.Next()) {
188 }// for (; aItW.More(); aItW.Next()) {
191 //=======================================================================
192 //function : MakeEdge
194 //=======================================================================
195 void GEOMAlgo_Gluer2::MakeEdge(const TopoDS_Edge& aE,
196 TopoDS_Edge& aNewEdge)
200 Standard_Boolean bIsDE;
201 Standard_Real aT1, aT2;
202 TopoDS_Vertex aV1, aV2, aVR1, aVR2;
205 bIsDE=BRep_Tool::Degenerated(aE);
208 aEx.Orientation(TopAbs_FORWARD);
210 TopExp::Vertices(aEx, aV1, aV2);
212 aT1=BRep_Tool::Parameter(aV1, aEx);
213 aT2=BRep_Tool::Parameter(aV2, aEx);
216 if (myOrigins.IsBound(aV1)) {
217 aVR1=*((TopoDS_Vertex*)&myOrigins.Find(aV1));
219 aVR1.Orientation(TopAbs_FORWARD);
222 if (myOrigins.IsBound(aV2)) {
223 aVR2=*((TopoDS_Vertex*)&myOrigins.Find(aV2));
225 aVR2.Orientation(TopAbs_REVERSED);
228 BOPTools_AlgoTools::MakeSplitEdge(aEx, aVR1, aT1, aVR2, aT2, aNewEdge);
235 aTol=BRep_Tool::Tolerance(aE);
242 aBB.Range(E, aT1, aT2);
243 aBB.Degenerated(E, Standard_True);
244 aBB.UpdateEdge(E, aTol);
249 //=======================================================================
250 //function : MakeVertex
252 //=======================================================================
253 void GEOMAlgo_Gluer2::MakeVertex(const TopTools_ListOfShape& aLV,
254 TopoDS_Vertex& aNewVertex)
256 Standard_Integer aNbV;
257 Standard_Real aTolV, aD, aDmax;
262 TopTools_ListIteratorOfListOfShape aIt;
270 aGC.SetCoord(0.,0.,0.);
272 for (; aIt.More(); aIt.Next()) {
273 aVx=*((TopoDS_Vertex*)(&aIt.Value()));
274 aP3D=BRep_Tool::Pnt(aVx);
277 aGC/=(Standard_Real)aNbV;
283 for (; aIt.More(); aIt.Next()) {
284 aVx=*((TopoDS_Vertex*)(&aIt.Value()));
285 aP3D=BRep_Tool::Pnt(aVx);
286 aTolV=BRep_Tool::Tolerance(aVx);
287 aD=aPGC.Distance(aP3D)+aTolV;
293 aBB.MakeVertex (aNewVertex, aPGC, aDmax);
295 //=======================================================================
296 //function : MapBRepShapes
298 //=======================================================================
299 void GEOMAlgo_Gluer2::MapBRepShapes(const TopoDS_Shape& aS,
300 TopTools_MapOfShape& aM)
302 //Standard_Boolean bHasBRep;
303 TopAbs_ShapeEnum aType;
306 aType=aS.ShapeType();
307 if (aType==TopAbs_VERTEX ||
308 aType==TopAbs_EDGE ||
309 aType==TopAbs_FACE) {
314 for(; aIt.More(); aIt.Next()) {
315 const TopoDS_Shape& aSx=aIt.Value();
316 aType=aSx.ShapeType();
317 GEOMAlgo_Gluer2::MapBRepShapes(aSx, aM);
324 // 40 - GEOMAlgo_GlueDetector is failed