File indexing completed on 2025-01-18 10:03:42
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017 #ifndef _GeomPlate_BuildAveragePlane_HeaderFile
0018 #define _GeomPlate_BuildAveragePlane_HeaderFile
0019
0020 #include <Standard.hxx>
0021 #include <Standard_DefineAlloc.hxx>
0022 #include <Standard_Handle.hxx>
0023
0024 #include <TColgp_HArray1OfPnt.hxx>
0025 #include <gp_Vec.hxx>
0026 #include <gp_Pnt.hxx>
0027 #include <Standard_Integer.hxx>
0028 #include <TColgp_SequenceOfVec.hxx>
0029 #include <GeomPlate_SequenceOfAij.hxx>
0030 class Geom_Plane;
0031 class Geom_Line;
0032
0033
0034
0035
0036
0037
0038 class GeomPlate_BuildAveragePlane
0039 {
0040 public:
0041
0042 DEFINE_STANDARD_ALLOC
0043
0044
0045
0046
0047
0048
0049
0050
0051 Standard_EXPORT GeomPlate_BuildAveragePlane(const Handle(TColgp_HArray1OfPnt)& Pts, const Standard_Integer NbBoundPoints, const Standard_Real Tol, const Standard_Integer POption, const Standard_Integer NOption);
0052
0053
0054 Standard_EXPORT GeomPlate_BuildAveragePlane(const TColgp_SequenceOfVec& Normals, const Handle(TColgp_HArray1OfPnt)& Pts);
0055
0056
0057
0058 Standard_EXPORT Handle(Geom_Plane) Plane() const;
0059
0060
0061
0062 Standard_EXPORT Handle(Geom_Line) Line() const;
0063
0064
0065 Standard_EXPORT Standard_Boolean IsPlane() const;
0066
0067
0068 Standard_EXPORT Standard_Boolean IsLine() const;
0069
0070
0071
0072 Standard_EXPORT void MinMaxBox (Standard_Real& Umin, Standard_Real& Umax, Standard_Real& Vmin, Standard_Real& Vmax) const;
0073
0074 Standard_EXPORT static Standard_Boolean HalfSpace (const TColgp_SequenceOfVec& NewNormals, TColgp_SequenceOfVec& Normals, GeomPlate_SequenceOfAij& Bset, const Standard_Real LinTol, const Standard_Real AngTol);
0075
0076
0077
0078
0079 protected:
0080
0081
0082
0083
0084
0085 private:
0086
0087
0088
0089
0090 Standard_EXPORT void BasePlan (const gp_Vec& N);
0091
0092
0093
0094
0095 Standard_EXPORT gp_Vec DefPlan (const Standard_Integer NOption);
0096
0097
0098 Handle(TColgp_HArray1OfPnt) myPts;
0099 Standard_Real myUmax;
0100 Standard_Real myVmax;
0101 Standard_Real myVmin;
0102 Standard_Real myUmin;
0103 Handle(Geom_Plane) myPlane;
0104 Standard_Real myTol;
0105 Handle(Geom_Line) myLine;
0106 gp_Vec myOX;
0107 gp_Vec myOY;
0108 gp_Pnt myG;
0109 Standard_Integer myNbBoundPoints;
0110
0111
0112 };
0113
0114
0115
0116
0117
0118
0119
0120 #endif