File indexing completed on 2025-01-18 10:03:16
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017 #ifndef _BRepPrim_Revolution_HeaderFile
0018 #define _BRepPrim_Revolution_HeaderFile
0019
0020 #include <Standard.hxx>
0021 #include <Standard_DefineAlloc.hxx>
0022 #include <Standard_Handle.hxx>
0023
0024 #include <BRepPrim_OneAxis.hxx>
0025 #include <Standard_Real.hxx>
0026 class Geom_Curve;
0027 class Geom2d_Curve;
0028 class gp_Ax2;
0029 class TopoDS_Face;
0030 class TopoDS_Edge;
0031 class gp_Pnt2d;
0032
0033
0034
0035
0036 class BRepPrim_Revolution : public BRepPrim_OneAxis
0037 {
0038 public:
0039
0040 DEFINE_STANDARD_ALLOC
0041
0042
0043
0044
0045
0046 Standard_EXPORT BRepPrim_Revolution(const gp_Ax2& A, const Standard_Real VMin, const Standard_Real VMax, const Handle(Geom_Curve)& M, const Handle(Geom2d_Curve)& PM);
0047
0048
0049
0050 Standard_EXPORT virtual TopoDS_Face MakeEmptyLateralFace() const;
0051
0052
0053
0054
0055 Standard_EXPORT virtual TopoDS_Edge MakeEmptyMeridianEdge (const Standard_Real Ang) const;
0056
0057
0058
0059 Standard_EXPORT virtual gp_Pnt2d MeridianValue (const Standard_Real V) const;
0060
0061
0062
0063
0064 Standard_EXPORT virtual void SetMeridianPCurve (TopoDS_Edge& E, const TopoDS_Face& F) const;
0065
0066
0067
0068
0069 protected:
0070
0071
0072
0073
0074 Standard_EXPORT BRepPrim_Revolution(const gp_Ax2& A, const Standard_Real VMin, const Standard_Real VMax);
0075
0076 Standard_EXPORT void Meridian (const Handle(Geom_Curve)& M, const Handle(Geom2d_Curve)& PM);
0077
0078
0079
0080
0081 private:
0082
0083
0084
0085 Handle(Geom_Curve) myMeridian;
0086 Handle(Geom2d_Curve) myPMeridian;
0087
0088
0089 };
0090
0091
0092
0093
0094
0095
0096
0097 #endif