Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023 #ifndef _GEOMAlgo_GlueAnalyser_HeaderFile
00024 #define _GEOMAlgo_GlueAnalyser_HeaderFile
00025
00026 #ifndef _GEOMAlgo_ListOfCoupleOfShapes_HeaderFile
00027 #include <GEOMAlgo_ListOfCoupleOfShapes.hxx>
00028 #endif
00029 #ifndef _TopTools_ListOfShape_HeaderFile
00030 #include <TopTools_ListOfShape.hxx>
00031 #endif
00032 #ifndef _GEOMAlgo_Gluer_HeaderFile
00033 #include <GEOMAlgo_Gluer.hxx>
00034 #endif
00035 #ifndef _Standard_Boolean_HeaderFile
00036 #include <Standard_Boolean.hxx>
00037 #endif
00038 #ifndef _TopAbs_ShapeEnum_HeaderFile
00039 #include <TopAbs_ShapeEnum.hxx>
00040 #endif
00041 class GEOMAlgo_ListOfCoupleOfShapes;
00042 class TopTools_ListOfShape;
00043
00044
00045 #ifndef _Standard_HeaderFile
00046 #include <Standard.hxx>
00047 #endif
00048 #ifndef _Standard_Macro_HeaderFile
00049 #include <Standard_Macro.hxx>
00050 #endif
00051
00052
00053 class GEOMAlgo_GlueAnalyser : public GEOMAlgo_Gluer {
00054
00055 public:
00056
00057 void* operator new(size_t,void* anAddress)
00058 {
00059 return anAddress;
00060 }
00061 void* operator new(size_t size)
00062 {
00063 return Standard::Allocate(size);
00064 }
00065 void operator delete(void *anAddress)
00066 {
00067 if (anAddress) Standard::Free((Standard_Address&)anAddress);
00068 }
00069
00070
00071
00072
00073 Standard_EXPORT GEOMAlgo_GlueAnalyser();
00074 Standard_EXPORT virtual ~GEOMAlgo_GlueAnalyser();
00075
00076
00077 Standard_EXPORT virtual void Perform() ;
00078
00079
00080 Standard_EXPORT Standard_Boolean HasSolidsToGlue() const;
00081
00082
00083 Standard_EXPORT const GEOMAlgo_ListOfCoupleOfShapes& SolidsToGlue() const;
00084
00085
00086 Standard_EXPORT Standard_Boolean HasSolidsAlone() const;
00087
00088
00089 Standard_EXPORT const TopTools_ListOfShape& SolidsAlone() const;
00090
00091
00092
00093
00094
00095 protected:
00096
00097
00098
00099
00100
00101 Standard_EXPORT void DetectVertices() ;
00102
00103
00104 Standard_EXPORT void DetectEdges() ;
00105
00106
00107 Standard_EXPORT void DetectFaces() ;
00108
00109
00110 Standard_EXPORT void DetectShapes(const TopAbs_ShapeEnum aType) ;
00111
00112
00113 Standard_EXPORT void DetectSolids() ;
00114
00115
00116
00117
00118 GEOMAlgo_ListOfCoupleOfShapes mySolidsToGlue;
00119 TopTools_ListOfShape mySolidsAlone;
00120
00121
00122 private:
00123
00124
00125
00126
00127
00128
00129
00130
00131
00132 };
00133
00134
00135
00136
00137
00138
00139
00140
00141
00142 #endif