// Copyright (C) 2007-2014 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, or (at your option) any later version. // // 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: GEOMAlgo_ClsfBox.cxx // Created: Wed Nov 22 10:41:47 2006 // Author: Peter KURNEV // // #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include IMPLEMENT_STANDARD_HANDLE(GEOMAlgo_ClsfBox, GEOMAlgo_Clsf) IMPLEMENT_STANDARD_RTTIEXT(GEOMAlgo_ClsfBox, GEOMAlgo_Clsf) //======================================================================= //function : //purpose : //======================================================================= GEOMAlgo_ClsfBox::GEOMAlgo_ClsfBox() : GEOMAlgo_Clsf() { } //======================================================================= //function : ~ //purpose : //======================================================================= GEOMAlgo_ClsfBox::~GEOMAlgo_ClsfBox() { } //======================================================================= //function : SetBox //purpose : //======================================================================= void GEOMAlgo_ClsfBox::SetBox(const TopoDS_Shape& aBox) { myBox=aBox; } //======================================================================= //function : Box //purpose : //======================================================================= const TopoDS_Shape& GEOMAlgo_ClsfBox::Box() const { return myBox; } //======================================================================= //function : CheckData //purpose : //======================================================================= void GEOMAlgo_ClsfBox::CheckData() { Standard_Integer i, aNbF; TopAbs_ShapeEnum aTypeShape; TopAbs_Orientation aOr; GeomAbs_SurfaceType aType; Handle(Geom_Surface) aS; TopTools_IndexedMapOfShape aMF; // myErrorStatus=0; // if(myBox.IsNull()) { myErrorStatus=10; // myBox=NULL return; } // aTypeShape=myBox.ShapeType(); if (aTypeShape!=TopAbs_SOLID) { myErrorStatus=11; // unallowed shape type return; } // TopExp::MapShapes(myBox, TopAbs_FACE, aMF); aNbF=aMF.Extent(); if (aNbF!=6) { myErrorStatus=12; // wrong number of faces return; } // for (i=1; i<=aNbF; ++i) { const TopoDS_Face& aF=TopoDS::Face(aMF(i)); aOr=aF.Orientation(); if (!(aOr==TopAbs_FORWARD || aOr==TopAbs_REVERSED)) { myErrorStatus=12; // unallowed orientation of face return; } // aS=BRep_Tool::Surface(aF); myGAS[i-1].Load(aS); aType=myGAS[i-1].GetType(); if (!aType==GeomAbs_Plane) { myErrorStatus=13; // unallowed surface type return; } // if(aOr==TopAbs_REVERSED) { gp_Ax3 aPos; gp_Pln aPln; gp_Pnt aP; gp_Dir aD; Handle(Geom_Plane) aSR; // aPln=myGAS[i-1].Plane(); aPos=aPln.Position(); aP=aPos.Location(); aD=aPos.Direction(); // Is aPos is not direct, aD is already a reversed direction. if (aPos.Direct()) { aD.Reverse(); } aSR=new Geom_Plane(aP, aD); myGAS[i-1].Load(aSR); } } } //======================================================================= //function : Perform //purpose : //======================================================================= void GEOMAlgo_ClsfBox::Perform() { myErrorStatus=0; // const Standard_Integer aNbS=6; Standard_Integer i, aNbON, aNbIN, iNext; TopAbs_State aSt; /* CheckData(); if(myErrorStatus) { return; } */ iNext=1; aNbON=0; aNbIN=0; for(i=0; i