File indexing completed on 2025-01-18 10:04:11
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017 #ifndef _IntTools_FClass2d_HeaderFile
0018 #define _IntTools_FClass2d_HeaderFile
0019
0020 #include <Standard.hxx>
0021 #include <Standard_DefineAlloc.hxx>
0022 #include <Standard_Handle.hxx>
0023
0024 #include <BRepClass_FaceExplorer.hxx>
0025 #include <BRepTopAdaptor_SeqOfPtr.hxx>
0026 #include <TColStd_SequenceOfInteger.hxx>
0027 #include <TopoDS_Face.hxx>
0028 #include <TopAbs_State.hxx>
0029 #include <memory>
0030
0031 class gp_Pnt2d;
0032
0033
0034
0035 class IntTools_FClass2d
0036 {
0037 public:
0038
0039 DEFINE_STANDARD_ALLOC
0040
0041
0042 Standard_EXPORT IntTools_FClass2d();
0043
0044
0045
0046 Standard_EXPORT IntTools_FClass2d(const TopoDS_Face& F, const Standard_Real Tol);
0047
0048
0049
0050 Standard_EXPORT void Init (const TopoDS_Face& F, const Standard_Real Tol);
0051
0052
0053 Standard_EXPORT TopAbs_State PerformInfinitePoint() const;
0054
0055
0056
0057
0058
0059 Standard_EXPORT TopAbs_State Perform (const gp_Pnt2d& Puv, const Standard_Boolean RecadreOnPeriodic = Standard_True) const;
0060
0061
0062 Standard_EXPORT ~IntTools_FClass2d();
0063
0064
0065
0066
0067 Standard_EXPORT TopAbs_State TestOnRestriction (const gp_Pnt2d& Puv, const Standard_Real Tol, const Standard_Boolean RecadreOnPeriodic = Standard_True) const;
0068
0069 Standard_EXPORT Standard_Boolean IsHole() const;
0070
0071 private:
0072
0073 BRepTopAdaptor_SeqOfPtr TabClass;
0074 TColStd_SequenceOfInteger TabOrien;
0075 Standard_Real Toluv;
0076 TopoDS_Face Face;
0077 Standard_Real U1;
0078 Standard_Real V1;
0079 Standard_Real U2;
0080 Standard_Real V2;
0081 Standard_Real Umin;
0082 Standard_Real Umax;
0083 Standard_Real Vmin;
0084 Standard_Real Vmax;
0085 Standard_Boolean myIsHole;
0086
0087 mutable std::unique_ptr<BRepClass_FaceExplorer> myFExplorer;
0088
0089 };
0090
0091 #endif