File indexing completed on 2025-01-18 10:03:39
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016 #ifndef _GeomFill_DiscreteTrihedron_HeaderFile
0017 #define _GeomFill_DiscreteTrihedron_HeaderFile
0018
0019 #include <Standard.hxx>
0020
0021 #include <GeomFill_HSequenceOfAx2.hxx>
0022 #include <TColStd_HSequenceOfReal.hxx>
0023 #include <GeomFill_TrihedronLaw.hxx>
0024 #include <Standard_Real.hxx>
0025 #include <Standard_Integer.hxx>
0026 #include <GeomAbs_Shape.hxx>
0027 #include <TColStd_Array1OfReal.hxx>
0028 class GeomFill_Frenet;
0029 class gp_Vec;
0030
0031
0032 class GeomFill_DiscreteTrihedron;
0033 DEFINE_STANDARD_HANDLE(GeomFill_DiscreteTrihedron, GeomFill_TrihedronLaw)
0034
0035
0036
0037
0038
0039 class GeomFill_DiscreteTrihedron : public GeomFill_TrihedronLaw
0040 {
0041
0042 public:
0043
0044
0045 Standard_EXPORT GeomFill_DiscreteTrihedron();
0046
0047 Standard_EXPORT virtual Handle(GeomFill_TrihedronLaw) Copy() const Standard_OVERRIDE;
0048
0049 Standard_EXPORT void Init();
0050
0051
0052
0053 Standard_EXPORT virtual Standard_Boolean SetCurve (const Handle(Adaptor3d_Curve)& C) Standard_OVERRIDE;
0054
0055
0056 Standard_EXPORT virtual Standard_Boolean D0 (const Standard_Real Param, gp_Vec& Tangent, gp_Vec& Normal, gp_Vec& BiNormal) Standard_OVERRIDE;
0057
0058
0059
0060
0061
0062
0063 Standard_EXPORT virtual Standard_Boolean D1 (const Standard_Real Param, gp_Vec& Tangent, gp_Vec& DTangent, gp_Vec& Normal, gp_Vec& DNormal, gp_Vec& BiNormal, gp_Vec& DBiNormal) Standard_OVERRIDE;
0064
0065
0066
0067
0068
0069
0070 Standard_EXPORT virtual Standard_Boolean D2 (const Standard_Real Param, gp_Vec& Tangent, gp_Vec& DTangent, gp_Vec& D2Tangent, gp_Vec& Normal, gp_Vec& DNormal, gp_Vec& D2Normal, gp_Vec& BiNormal, gp_Vec& DBiNormal, gp_Vec& D2BiNormal) Standard_OVERRIDE;
0071
0072
0073
0074
0075 Standard_EXPORT virtual Standard_Integer NbIntervals (const GeomAbs_Shape S) const Standard_OVERRIDE;
0076
0077
0078
0079
0080
0081
0082 Standard_EXPORT virtual void Intervals (TColStd_Array1OfReal& T, const GeomAbs_Shape S) const Standard_OVERRIDE;
0083
0084
0085
0086 Standard_EXPORT virtual void GetAverageLaw (gp_Vec& ATangent, gp_Vec& ANormal, gp_Vec& ABiNormal) Standard_OVERRIDE;
0087
0088
0089 Standard_EXPORT virtual Standard_Boolean IsConstant() const Standard_OVERRIDE;
0090
0091
0092 Standard_EXPORT virtual Standard_Boolean IsOnlyBy3dCurve() const Standard_OVERRIDE;
0093
0094
0095
0096
0097 DEFINE_STANDARD_RTTIEXT(GeomFill_DiscreteTrihedron,GeomFill_TrihedronLaw)
0098
0099 protected:
0100
0101
0102
0103
0104 private:
0105
0106
0107 gp_Pnt myPoint;
0108 Handle(GeomFill_HSequenceOfAx2) myTrihedrons;
0109 Handle(TColStd_HSequenceOfReal) myKnots;
0110 Handle(GeomFill_Frenet) myFrenet;
0111 Standard_Boolean myUseFrenet;
0112
0113
0114 };
0115
0116
0117
0118
0119
0120
0121
0122 #endif