2009-01-13 23:32:10 +05:00
|
|
|
// GEOM PARTITION : partition algorithm
|
|
|
|
//
|
|
|
|
// Copyright (C) 2003 CEA/DEN, EDF R&D
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// File : Partition_Loop3d.hxx
|
|
|
|
// Module : GEOM
|
|
|
|
|
|
|
|
#ifndef _Partition_Loop3d_HeaderFile
|
|
|
|
#define _Partition_Loop3d_HeaderFile
|
|
|
|
|
|
|
|
#ifndef _TopTools_ListOfShape_HeaderFile
|
|
|
|
#include <TopTools_ListOfShape.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _TopTools_IndexedDataMapOfShapeListOfShape_HeaderFile
|
|
|
|
#include <TopTools_IndexedDataMapOfShapeListOfShape.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _Standard_Boolean_HeaderFile
|
|
|
|
#include <Standard_Boolean.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _Standard_Real_HeaderFile
|
|
|
|
#include <Standard_Real.hxx>
|
|
|
|
#endif
|
2017-01-31 23:21:25 +05:00
|
|
|
#ifndef _Standard_Version_HeaderFile
|
|
|
|
#include <Standard_Version.hxx>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if OCC_VERSION_HEX < 0x070000
|
|
|
|
#else
|
|
|
|
#include <TopTools_ShapeMapHasher.hxx>
|
|
|
|
#include <TopTools_MapOfOrientedShape.hxx>
|
|
|
|
#endif
|
|
|
|
|
2009-01-13 23:32:10 +05:00
|
|
|
class TopoDS_Shape;
|
2017-01-31 23:21:25 +05:00
|
|
|
|
|
|
|
#if OCC_VERSION_HEX < 0x070000
|
|
|
|
class TopTools_ListOfShape;
|
|
|
|
class TopTools_MapOfOrientedShape;
|
|
|
|
#endif
|
|
|
|
|
2009-01-13 23:32:10 +05:00
|
|
|
class TopoDS_Edge;
|
|
|
|
class TopoDS_Face;
|
|
|
|
class gp_Vec;
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef _Standard_HeaderFile
|
|
|
|
#include <Standard.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _Standard_Macro_HeaderFile
|
|
|
|
#include <Standard_Macro.hxx>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
class Partition_Loop3d {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
2009-04-05 03:43:55 +06:00
|
|
|
void* operator new(size_t,void* anAddress)
|
|
|
|
{
|
|
|
|
return anAddress;
|
|
|
|
}
|
|
|
|
void* operator new(size_t size)
|
|
|
|
{
|
|
|
|
return Standard::Allocate(size);
|
|
|
|
}
|
|
|
|
void operator delete(void *anAddress)
|
|
|
|
{
|
|
|
|
if (anAddress) Standard::Free((Standard_Address&)anAddress);
|
|
|
|
}
|
|
|
|
// Methods PUBLIC
|
|
|
|
//
|
|
|
|
Partition_Loop3d();
|
|
|
|
void AddConstFaces(const TopoDS_Shape& S) ;
|
|
|
|
void AddSectionFaces(const TopoDS_Shape& S) ;
|
|
|
|
const TopTools_ListOfShape& MakeShells(const TopTools_MapOfOrientedShape& AvoidFacesMap) ;
|
|
|
|
static Standard_Boolean IsInside(const TopoDS_Edge& E,const TopoDS_Face& F1,const TopoDS_Face& F2,const Standard_Boolean CountDot,Standard_Real& Dot,Standard_Boolean& GoodOri) ;
|
|
|
|
static gp_Vec Normal(const TopoDS_Edge& E,const TopoDS_Face& F) ;
|
2009-01-13 23:32:10 +05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
2009-04-05 03:43:55 +06:00
|
|
|
// Methods PROTECTED
|
|
|
|
//
|
2009-01-13 23:32:10 +05:00
|
|
|
|
|
|
|
|
2009-04-05 03:43:55 +06:00
|
|
|
// Fields PROTECTED
|
|
|
|
//
|
2009-01-13 23:32:10 +05:00
|
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
2009-04-05 03:43:55 +06:00
|
|
|
// Methods PRIVATE
|
|
|
|
//
|
2009-01-13 23:32:10 +05:00
|
|
|
|
|
|
|
|
2009-04-05 03:43:55 +06:00
|
|
|
// Fields PRIVATE
|
|
|
|
//
|
|
|
|
TopTools_ListOfShape myNewShells;
|
|
|
|
TopTools_ListOfShape myFaces;
|
|
|
|
TopTools_IndexedDataMapOfShapeListOfShape myEFMap;
|
2009-01-13 23:32:10 +05:00
|
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// other Inline functions and methods (like "C++: function call" methods)
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|