// Copyright (C) 2007-2008 CEA/DEN, EDF R&D, OPEN CASCADE // // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 2.1 of the License. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // // File: NMTAlgo_WESCorrector.cxx // Created: // Author: Peter KURNEV // // #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include static void MakeWire(const TopTools_ListOfShape& aLE, TopoDS_Wire& newWire); //======================================================================= // function: // purpose: //======================================================================= GEOMAlgo_WESCorrector::GEOMAlgo_WESCorrector() : GEOMAlgo_Algo() { } //======================================================================= // function: ~ // purpose: //======================================================================= GEOMAlgo_WESCorrector::~GEOMAlgo_WESCorrector() { } //======================================================================= // function: SetWES // purpose: //======================================================================= void GEOMAlgo_WESCorrector::SetWES (const GEOMAlgo_WireEdgeSet& aWES) { GEOMAlgo_WireEdgeSet* pWES=(GEOMAlgo_WireEdgeSet*) &aWES; myWES=pWES; } //======================================================================= // function: WES // purpose: //======================================================================= GEOMAlgo_WireEdgeSet& GEOMAlgo_WESCorrector::WES () { return *myWES; } //======================================================================= // function: NewWES // purpose: //======================================================================= GEOMAlgo_WireEdgeSet& GEOMAlgo_WESCorrector::NewWES () { return myNewWES; } //======================================================================= // function: Perform // purpose: //======================================================================= void GEOMAlgo_WESCorrector::Perform() { myErrorStatus=0; // DoConnexityBlocks(); DoCorrections(); } //======================================================================= // function: DoConnexityBlocks // purpose: //======================================================================= void GEOMAlgo_WESCorrector::DoConnexityBlocks() { Standard_Boolean bRegular, bClosed; Standard_Integer i, aNbV, j, aNbC, aNbVP, aNbVS; TopTools_ListIteratorOfListOfShape aIt; TopoDS_Iterator aItE; TopoDS_Shape aER; TopTools_IndexedMapOfShape aMER, aMEP, aMEC, aMVP; TopTools_IndexedMapOfShape aMVS, aMVAdd; TopTools_IndexedDataMapOfShapeListOfShape aMVE; // // 1. aMVE; const TopTools_ListOfShape& aLSE=myWES->StartElements(); aIt.Initialize(aLSE); for (; aIt.More(); aIt.Next()) { const TopoDS_Shape& aE=aIt.Value(); if (!aMEP.Contains(aE)) { aMEP.Add(aE); TopExp::MapShapesAndAncestors(aE, TopAbs_VERTEX, TopAbs_EDGE, aMVE); } else { aMER.Add(aE); } } // // 2. aNbV=aMVE.Extent(); for (i=1; i<=aNbV; ++i) { const TopoDS_Shape& aV=aMVE.FindKey(i); // aNbVS=aMVS.Extent(); if (aNbVS==aNbV) { break; } // if (aMVS.Contains(aV)) { continue; } aMVS.Add(aV); // aMVS - globally processed vertices // //------------------------------------- goal: aMEC aMEC.Clear(); // aMEC - edges of CB aMVP.Clear(); // aMVP - vertices to process right now aMVAdd.Clear(); // aMVAdd vertices to process on next step of while(1) // aMVP.Add(aV); // while(1) { aNbVP=aMVP.Extent(); for (j=1; j<=aNbVP; ++j) { const TopoDS_Shape& aVP=aMVP(j); const TopTools_ListOfShape& aLE=aMVE.FindFromKey(aVP); aIt.Initialize(aLE); for (; aIt.More(); aIt.Next()) { const TopoDS_Shape& aE=aIt.Value(); if (aMEC.Contains(aE)) { continue; } aMEC.Add(aE); // aItE.Initialize(aE); for (; aItE.More(); aItE.Next()) { const TopoDS_Shape& aVE=aItE.Value(); if (!aMVS.Contains(aVE)) { aMVS.Add(aVE); aMVAdd.Add(aVE); } } } }//for (j=1; j<=aNbVP; ++j) // aNbVP=aMVAdd.Extent(); if (!aNbVP) { break; // from while(1) } // aMVP.Clear(); for (j=1; j<=aNbVP; ++j) { const TopoDS_Shape& aVE=aMVAdd(j); aMVP.Add(aVE); } aMVAdd.Clear(); }// while(1) { //------------------------------------- BOP_ConnexityBlock aCB; TopTools_ListOfShape aLEC; TopTools_IndexedDataMapOfShapeListOfShape aMVER; // bRegular=Standard_True; aNbC=aMEC.Extent(); for (j=1; j<=aNbC; ++j) { aER=aMEC(j); // if (aMER.Contains(aER)) { aER.Orientation(TopAbs_FORWARD); aLEC.Append(aER); aER.Orientation(TopAbs_REVERSED); aLEC.Append(aER); // //modified by NIZNHY-PKV Tue Nov 28 12:02:29 2006f //bClosed=BRep_Tool::IsClosed(TopoDS::Edge(aER), myWES->Face()); //if (!bClosed) { bRegular=Standard_False; //} //modified by NIZNHY-PKV Tue Nov 28 12:02:33 2006t } else { aLEC.Append(aER); } // if (bRegular) { TopExp::MapShapesAndAncestors(aER, TopAbs_VERTEX, TopAbs_EDGE, aMVER); } }//for (j=1; j<=aNbC; ++j) { // if (bRegular) { Standard_Integer k, aNbVR, aNbER; // aNbVR=aMVER.Extent(); for (k=1; k<=aNbVR; ++k) { const TopTools_ListOfShape& aLER=aMVER(k); aNbER=aLER.Extent(); if (aNbER==1) { const TopoDS_Edge& aEx=TopoDS::Edge(aER); bClosed=BRep_Tool::IsClosed(aEx, myWES->Face()); if (!bClosed) { bRegular=!bRegular; break; } } if (aNbER>2) { bRegular=!bRegular; break; } } } // aCB.SetShapes(aLEC); aCB.SetRegularity(bRegular); myConnexityBlocks.Append(aCB); aMEC.Clear(); }//for (i=1; i<=aNbV; ++i) { } //======================================================================= // function: DoCorrections // purpose: //======================================================================= void GEOMAlgo_WESCorrector::DoCorrections() { Standard_Boolean bIsRegular, bIsNothingToDo; Standard_Integer iErr; TopoDS_Wire aW; BOP_ListIteratorOfListOfConnexityBlock aCBIt; // const TopoDS_Face& aF=myWES->Face(); // myNewWES.SetFace(aF); aCBIt.Initialize(myConnexityBlocks); for (; aCBIt.More(); aCBIt.Next()) { const BOP_ConnexityBlock& aCB=aCBIt.Value(); const TopTools_ListOfShape& aLE=aCB.Shapes(); bIsRegular=aCB.IsRegular(); if (bIsRegular) { MakeWire(aLE, aW); myNewWES.AddShape (aW); continue; } // GEOMAlgo_WireSplitter aWS; // aWS.SetFace(aF); aWS.SetEdges(aLE); // aWS.Perform(); iErr=aWS.ErrorStatus(); if (iErr) { continue; } bIsNothingToDo=aWS.IsNothingToDo(); if (bIsNothingToDo) { MakeWire(aLE, aW); myNewWES.AddShape (aW); continue; } // const BOPTColStd_ListOfListOfShape& aSSS=aWS.Shapes(); BOPTColStd_ListIteratorOfListOfListOfShape aWireIt(aSSS); for (; aWireIt.More(); aWireIt.Next()) { const TopTools_ListOfShape& aLEx=aWireIt.Value(); // MakeWire(aLEx, aW); myNewWES.AddShape (aW); } } } //======================================================================= // function: MakeWire // purpose: //======================================================================= void MakeWire(const TopTools_ListOfShape& aLE, TopoDS_Wire& newWire) { BRep_Builder aBB; aBB.MakeWire(newWire); TopTools_ListIteratorOfListOfShape anIt(aLE); for (; anIt.More(); anIt.Next()){ const TopoDS_Edge& aE=TopoDS::Edge(anIt.Value()); aBB.Add(newWire, aE); } }