2014-02-18 12:44:41 +06:00
|
|
|
// Copyright (C) 2007-2014 CEA/DEN, EDF R&D, OPEN CASCADE
|
2005-12-05 21:23:52 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
|
|
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
2005-12-05 21:23:52 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
// 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
|
2014-02-18 12:44:41 +06:00
|
|
|
// version 2.1 of the License, or (at your option) any later version.
|
2009-02-13 17:16:39 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
// 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.
|
2009-02-13 17:16:39 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
// 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
|
2009-02-13 17:16:39 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
2005-12-05 21:23:52 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
|
|
|
|
// File: GEOMAlgo_ShellSolid.cxx
|
|
|
|
// Created: Wed Jan 12 12:49:45 2005
|
|
|
|
// Author: Peter KURNEV
|
|
|
|
// <pkv@irinox>
|
2009-02-13 17:16:39 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
#include <GEOMAlgo_ShellSolid.hxx>
|
2005-06-02 15:34:45 +06:00
|
|
|
|
2014-06-09 14:56:21 +06:00
|
|
|
#include <Basics_OCCTVersion.hxx>
|
|
|
|
|
2005-06-02 15:34:45 +06:00
|
|
|
#include <Standard_Failure.hxx>
|
|
|
|
|
|
|
|
#include <gp_Pnt2d.hxx>
|
|
|
|
#include <gp_Pnt.hxx>
|
|
|
|
#include <gp_Dir.hxx>
|
|
|
|
|
|
|
|
#include <TopoDS.hxx>
|
|
|
|
#include <TopoDS_Face.hxx>
|
|
|
|
#include <TopoDS_Edge.hxx>
|
|
|
|
#include <TopoDS_Shape.hxx>
|
|
|
|
#include <TopoDS_Solid.hxx>
|
|
|
|
|
|
|
|
#include <BRep_Tool.hxx>
|
|
|
|
#include <BRepTools.hxx>
|
|
|
|
|
|
|
|
#include <TopTools_ListOfShape.hxx>
|
|
|
|
#include <TopTools_ListIteratorOfListOfShape.hxx>
|
|
|
|
#include <TopExp_Explorer.hxx>
|
|
|
|
|
2013-09-16 19:59:50 +06:00
|
|
|
#include <BOPTools_AlgoTools.hxx>
|
2005-06-02 15:34:45 +06:00
|
|
|
|
2013-09-16 19:59:50 +06:00
|
|
|
#include <BOPCol_DataMapOfShapeListOfShape.hxx>
|
|
|
|
#include <BOPCol_ListOfShape.hxx>
|
2014-06-09 14:56:21 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06070100
|
|
|
|
#include <IntTools_Context.hxx>
|
|
|
|
#else
|
2013-09-16 19:59:50 +06:00
|
|
|
#include <BOPInt_Context.hxx>
|
2014-06-09 14:56:21 +06:00
|
|
|
#endif
|
2013-09-16 19:59:50 +06:00
|
|
|
#include <BOPDS_DS.hxx>
|
|
|
|
#include <BOPAlgo_Builder.hxx>
|
2005-06-02 15:34:45 +06:00
|
|
|
|
2013-09-16 19:59:50 +06:00
|
|
|
#include <GEOMAlgo_AlgoTools.hxx>
|
|
|
|
/////////////////////////////////////////////////////////////////////////
|
|
|
|
//=======================================================================
|
|
|
|
//class : GEOMAlgo_ShellSolidBuilder
|
|
|
|
//purpose :
|
|
|
|
//=======================================================================
|
|
|
|
class GEOMAlgo_ShellSolidBuilder : public BOPAlgo_Builder {
|
|
|
|
public:
|
|
|
|
Standard_EXPORT
|
|
|
|
GEOMAlgo_ShellSolidBuilder();
|
2005-06-02 15:34:45 +06:00
|
|
|
|
2013-09-16 19:59:50 +06:00
|
|
|
Standard_EXPORT
|
|
|
|
virtual ~GEOMAlgo_ShellSolidBuilder();
|
2005-06-02 15:34:45 +06:00
|
|
|
|
2013-09-16 19:59:50 +06:00
|
|
|
protected:
|
|
|
|
Standard_EXPORT
|
|
|
|
virtual void PerformInternal(const BOPAlgo_PaveFiller& theFiller);
|
|
|
|
};
|
|
|
|
|
|
|
|
//=======================================================================
|
|
|
|
//function : GEOMAlgo_ShellSolidBuilder
|
|
|
|
//purpose :
|
|
|
|
//=======================================================================
|
|
|
|
GEOMAlgo_ShellSolidBuilder::GEOMAlgo_ShellSolidBuilder()
|
|
|
|
:
|
|
|
|
BOPAlgo_Builder()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
//=======================================================================
|
|
|
|
//function : ~GEOMAlgo_ShellSolidBuilder
|
|
|
|
//purpose :
|
|
|
|
//=======================================================================
|
|
|
|
GEOMAlgo_ShellSolidBuilder::~GEOMAlgo_ShellSolidBuilder()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
//=======================================================================
|
|
|
|
//function : PerformInternal
|
|
|
|
//purpose :
|
|
|
|
//=======================================================================
|
|
|
|
void GEOMAlgo_ShellSolidBuilder::PerformInternal(const BOPAlgo_PaveFiller& theFiller)
|
|
|
|
{
|
|
|
|
myErrorStatus=0;
|
|
|
|
//
|
|
|
|
myPaveFiller=(BOPAlgo_PaveFiller*)&theFiller;
|
|
|
|
myDS=myPaveFiller->PDS();
|
|
|
|
myContext=myPaveFiller->Context();
|
|
|
|
//
|
|
|
|
// 1. CheckData
|
|
|
|
CheckData();
|
|
|
|
if (myErrorStatus) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
// 2. Prepare
|
|
|
|
Prepare();
|
|
|
|
if (myErrorStatus) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
// 3. Fill Images
|
|
|
|
// 3.1 Vertice
|
|
|
|
FillImagesVertices();
|
|
|
|
if (myErrorStatus) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
BuildResult(TopAbs_VERTEX);
|
|
|
|
if (myErrorStatus) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// 3.2 Edges
|
|
|
|
FillImagesEdges();
|
|
|
|
if (myErrorStatus) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
BuildResult(TopAbs_EDGE);
|
|
|
|
if (myErrorStatus) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
// 3.3 Wires
|
|
|
|
FillImagesContainers(TopAbs_WIRE);
|
|
|
|
if (myErrorStatus) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
BuildResult(TopAbs_WIRE);
|
|
|
|
if (myErrorStatus) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// 3.4 Faces
|
|
|
|
FillImagesFaces();
|
|
|
|
if (myErrorStatus) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
BuildResult(TopAbs_FACE);
|
|
|
|
if (myErrorStatus) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/////////////////////////////////////////////////////////////////////////
|
2005-06-02 15:34:45 +06:00
|
|
|
//=======================================================================
|
|
|
|
//function : GEOMAlgo_ShellSolid
|
2012-08-09 13:58:02 +06:00
|
|
|
//purpose :
|
2005-06-02 15:34:45 +06:00
|
|
|
//=======================================================================
|
|
|
|
GEOMAlgo_ShellSolid::GEOMAlgo_ShellSolid()
|
|
|
|
:
|
|
|
|
GEOMAlgo_ShapeSolid()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
//=======================================================================
|
|
|
|
//function : ~
|
2012-08-09 13:58:02 +06:00
|
|
|
//purpose :
|
2005-06-02 15:34:45 +06:00
|
|
|
//=======================================================================
|
|
|
|
GEOMAlgo_ShellSolid::~GEOMAlgo_ShellSolid()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
//=======================================================================
|
2012-08-09 13:58:02 +06:00
|
|
|
// function:
|
|
|
|
// purpose:
|
2005-06-02 15:34:45 +06:00
|
|
|
//=======================================================================
|
2012-08-09 13:58:02 +06:00
|
|
|
void GEOMAlgo_ShellSolid::Perform()
|
2005-06-02 15:34:45 +06:00
|
|
|
{
|
|
|
|
myErrorStatus=0;
|
|
|
|
//
|
|
|
|
try {
|
2013-09-16 19:59:50 +06:00
|
|
|
Standard_Integer aNbArgs, iRank, iErr, iBeg, iEnd, i, aNbSp;
|
|
|
|
Standard_Real aTol;
|
|
|
|
TopAbs_ShapeEnum aType;
|
|
|
|
TopAbs_State aState;
|
|
|
|
gp_Pnt aP;
|
|
|
|
gp_Pnt2d aP2D;
|
|
|
|
TopoDS_Face aF;
|
|
|
|
//
|
|
|
|
myLSIN.Clear();
|
|
|
|
myLSOUT.Clear();
|
|
|
|
myLSON.Clear();
|
|
|
|
//
|
|
|
|
aTol=1.e-7;
|
|
|
|
//
|
2005-06-02 15:34:45 +06:00
|
|
|
if (myDSFiller==NULL) {
|
|
|
|
myErrorStatus=10;
|
|
|
|
return;
|
|
|
|
}
|
2013-09-16 19:59:50 +06:00
|
|
|
if(myDSFiller->ErrorStatus()) {
|
2005-06-02 15:34:45 +06:00
|
|
|
myErrorStatus=11;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
2013-09-16 19:59:50 +06:00
|
|
|
const BOPDS_DS& aDS=myDSFiller->DS();
|
|
|
|
BOPDS_DS* pDS=(BOPDS_DS*)&aDS;
|
|
|
|
const BOPCol_ListOfShape& aLS=pDS->Arguments();
|
2005-06-02 15:34:45 +06:00
|
|
|
//
|
2013-09-16 19:59:50 +06:00
|
|
|
aNbArgs=aLS.Extent();
|
|
|
|
if (aNbArgs!=2) {
|
|
|
|
myErrorStatus=13;
|
|
|
|
return;
|
2005-06-02 15:34:45 +06:00
|
|
|
}
|
|
|
|
//
|
2013-09-16 19:59:50 +06:00
|
|
|
iRank=-1;
|
|
|
|
const TopoDS_Shape& aObj=aLS.First();
|
|
|
|
if (aObj.ShapeType()==TopAbs_SHELL) {
|
|
|
|
iRank=0;
|
2005-06-02 15:34:45 +06:00
|
|
|
}
|
2013-09-16 19:59:50 +06:00
|
|
|
const TopoDS_Shape& aTool=aLS.Last();
|
|
|
|
if (aTool.ShapeType()==TopAbs_SHELL) {
|
|
|
|
iRank=1;
|
2005-06-02 15:34:45 +06:00
|
|
|
}
|
|
|
|
//
|
2013-09-16 19:59:50 +06:00
|
|
|
if (iRank==-1) {
|
|
|
|
myErrorStatus=14;
|
|
|
|
return;
|
|
|
|
}
|
2005-06-02 15:34:45 +06:00
|
|
|
//
|
2014-06-09 14:56:21 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06070100
|
|
|
|
Handle(IntTools_Context) aCtx=myDSFiller->Context();
|
|
|
|
#else
|
2013-09-16 19:59:50 +06:00
|
|
|
Handle(BOPInt_Context) aCtx=myDSFiller->Context();
|
2014-06-09 14:56:21 +06:00
|
|
|
#endif
|
2013-09-16 19:59:50 +06:00
|
|
|
const BOPDS_IndexRange& aRange=pDS->Range(iRank);
|
|
|
|
aRange.Indices(iBeg, iEnd);
|
|
|
|
const TopoDS_Solid& aSolid=(!iRank) ? *((TopoDS_Solid*)&aTool) : *((TopoDS_Solid*)&aObj);
|
|
|
|
BRepClass3d_SolidClassifier& aSC=aCtx->SolidClassifier(aSolid);
|
2005-06-02 15:34:45 +06:00
|
|
|
//
|
2013-09-16 19:59:50 +06:00
|
|
|
//------------------------------ShellSolidBuilder
|
|
|
|
GEOMAlgo_ShellSolidBuilder aSSB;
|
2005-06-02 15:34:45 +06:00
|
|
|
//
|
2013-09-16 19:59:50 +06:00
|
|
|
aSSB.PerformWithFiller(*myDSFiller);
|
|
|
|
iErr=aSSB.ErrorStatus();
|
|
|
|
if (iErr) {
|
|
|
|
myErrorStatus=15;
|
|
|
|
return;
|
2005-06-02 15:34:45 +06:00
|
|
|
}
|
|
|
|
//
|
2013-09-16 19:59:50 +06:00
|
|
|
const BOPCol_DataMapOfShapeListOfShape& aImages=aSSB.Images();
|
2005-06-02 15:34:45 +06:00
|
|
|
//
|
2013-09-16 19:59:50 +06:00
|
|
|
//-------------------------------
|
|
|
|
for (i=iBeg; i<=iEnd; ++i) {
|
|
|
|
const TopoDS_Shape& aS=pDS->Shape(i);
|
|
|
|
aType=aS.ShapeType();
|
|
|
|
if (aType!=TopAbs_FACE) {
|
|
|
|
continue;
|
2005-06-02 15:34:45 +06:00
|
|
|
}
|
|
|
|
//
|
2013-09-16 19:59:50 +06:00
|
|
|
aState=TopAbs_UNKNOWN;
|
|
|
|
aF=*((TopoDS_Face*)&aS);
|
2005-06-02 15:34:45 +06:00
|
|
|
//
|
2013-09-16 19:59:50 +06:00
|
|
|
if (!aImages.IsBound(aS)) {
|
|
|
|
iErr=GEOMAlgo_AlgoTools::PntInFace(aF, aP, aP2D);
|
|
|
|
if (iErr) {
|
|
|
|
myErrorStatus=16;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
aState=BOPTools_AlgoTools::ComputeState(aP, aSolid, aTol, aCtx);
|
2005-06-02 15:34:45 +06:00
|
|
|
}
|
2013-09-16 19:59:50 +06:00
|
|
|
else {
|
|
|
|
const BOPCol_ListOfShape& aLSp=aImages.Find(aS);
|
|
|
|
aNbSp=aLSp.Extent();
|
|
|
|
if (aNbSp>0) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
if (aNbSp==1) {
|
|
|
|
aF=*((TopoDS_Face*)&aLSp.First());
|
|
|
|
}
|
|
|
|
//
|
|
|
|
iErr=GEOMAlgo_AlgoTools::PntInFace(aF, aP, aP2D);
|
|
|
|
if (iErr) {
|
|
|
|
myErrorStatus=16;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
aState=BOPTools_AlgoTools::ComputeState(aP, aSolid, aTol, aCtx);
|
2005-06-02 15:34:45 +06:00
|
|
|
}
|
2013-09-16 19:59:50 +06:00
|
|
|
//----------
|
|
|
|
if (aState==TopAbs_ON) {
|
|
|
|
myLSON.Append(aF);
|
|
|
|
}
|
|
|
|
else if (aState==TopAbs_OUT) {
|
|
|
|
myLSOUT.Append(aF);
|
|
|
|
}
|
|
|
|
else if (aState==TopAbs_IN) {
|
|
|
|
myLSIN.Append(aF);
|
|
|
|
}
|
|
|
|
//----------
|
|
|
|
}//for (i=iBeg; i<=iEnd; ++i) {
|
|
|
|
|
|
|
|
}// try
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
myErrorStatus=12;
|
|
|
|
}
|
2005-06-02 15:34:45 +06:00
|
|
|
}
|