Open CASCADE Technology 7.8.2.dev
GeomAdaptor_SurfaceOfRevolution Class Reference

This class defines a complete surface of revolution. The surface is obtained by rotating a curve a complete revolution about an axis. The curve and the axis must be in the same plane. If the curve and the axis are not in the same plane it is always possible to be in the previous case after a cylindrical projection of the curve in a referenced plane. For a complete surface of revolution the parametric range is 0 <= U <= 2*PI. – The parametric range for V is defined with the revolved curve. The origin of the U parametrization is given by the position of the revolved curve (reference). The direction of the revolution axis defines the positive sense of rotation (trigonometric sense) corresponding to the increasing of the parametric value U. The derivatives are always defined for the u direction. For the v direction the definition of the derivatives depends on the degree of continuity of the referenced curve. More...

#include <GeomAdaptor_SurfaceOfRevolution.hxx>

Inheritance diagram for GeomAdaptor_SurfaceOfRevolution:

Public Member Functions

 GeomAdaptor_SurfaceOfRevolution ()
 
 GeomAdaptor_SurfaceOfRevolution (const Handle< Adaptor3d_Curve > &C)
 The Curve is loaded.
 
 GeomAdaptor_SurfaceOfRevolution (const Handle< Adaptor3d_Curve > &C, const gp_Ax1 &V)
 The Curve and the Direction are loaded.
 
virtual Handle< Adaptor3d_SurfaceShallowCopy () const override
 Shallow copy of adaptor.
 
void Load (const Handle< Adaptor3d_Curve > &C)
 Changes the Curve.
 
void Load (const gp_Ax1 &V)
 Changes the Direction.
 
gp_Ax1 AxeOfRevolution () const override
 
Standard_Real FirstUParameter () const override
 
Standard_Real LastUParameter () const override
 
Standard_Real FirstVParameter () const override
 
Standard_Real LastVParameter () const override
 
GeomAbs_Shape UContinuity () const override
 
GeomAbs_Shape VContinuity () const override
 Return CN.
 
Standard_Integer NbUIntervals (const GeomAbs_Shape S) const override
 Returns the number of U intervals for continuity . May be one if UContinuity(me) >=
 
Standard_Integer NbVIntervals (const GeomAbs_Shape S) const override
 Returns the number of V intervals for continuity . May be one if VContinuity(me) >=
 
void UIntervals (TColStd_Array1OfReal &T, const GeomAbs_Shape S) const override
 Returns the intervals with the requested continuity in the U direction.
 
void VIntervals (TColStd_Array1OfReal &T, const GeomAbs_Shape S) const override
 Returns the intervals with the requested continuity in the V direction.
 
Handle< Adaptor3d_SurfaceUTrim (const Standard_Real First, const Standard_Real Last, const Standard_Real Tol) const override
 Returns a surface trimmed in the U direction equivalent of <me> between parameters <First> and <Last>. <Tol> is used to test for 3d points confusion. If <First> >= <Last>
 
Handle< Adaptor3d_SurfaceVTrim (const Standard_Real First, const Standard_Real Last, const Standard_Real Tol) const override
 Returns a surface trimmed in the V direction between parameters <First> and <Last>. <Tol> is used to test for 3d points confusion. If <First> >= <Last>
 
Standard_Boolean IsUClosed () const override
 
Standard_Boolean IsVClosed () const override
 
Standard_Boolean IsUPeriodic () const override
 
Standard_Real UPeriod () const override
 
Standard_Boolean IsVPeriodic () const override
 
Standard_Real VPeriod () const override
 
Standard_Real UResolution (const Standard_Real R3d) const override
 Returns the parametric U resolution corresponding to the real space resolution <R3d>.
 
Standard_Real VResolution (const Standard_Real R3d) const override
 Returns the parametric V resolution corresponding to the real space resolution <R3d>.
 
GeomAbs_SurfaceType GetType () const override
 Returns the type of the surface : Plane, Cylinder, Cone, Sphere, Torus, BezierSurface, BSplineSurface, SurfaceOfRevolution, SurfaceOfExtrusion, OtherSurface.
 
gp_Pln Plane () const override
 
gp_Cylinder Cylinder () const override
 
gp_Cone Cone () const override
 Apex of the Cone = Cone.Position().Location() ==> ReferenceRadius = 0.
 
gp_Sphere Sphere () const override
 
gp_Torus Torus () const override
 
Standard_Integer VDegree () const override
 
Standard_Integer NbVPoles () const override
 
Standard_Integer NbVKnots () const override
 
Standard_Boolean IsURational () const override
 
Standard_Boolean IsVRational () const override
 
Handle< Geom_BezierSurfaceBezier () const override
 This will NOT make a copy of the Bezier Surface : If you want to modify the Surface please make a copy yourself Also it will NOT trim the surface to myU/VFirst/Last.
 
Handle< Geom_BSplineSurfaceBSpline () const override
 This will NOT make a copy of the BSpline Surface : If you want to modify the Surface please make a copy yourself Also it will NOT trim the surface to myU/VFirst/Last.
 
const gp_Ax3Axis () const
 
Handle< Adaptor3d_CurveBasisCurve () const override
 
- Public Member Functions inherited from GeomAdaptor_Surface
 GeomAdaptor_Surface ()
 
 GeomAdaptor_Surface (const Handle< Geom_Surface > &theSurf)
 
 GeomAdaptor_Surface (const Handle< Geom_Surface > &theSurf, const Standard_Real theUFirst, const Standard_Real theULast, const Standard_Real theVFirst, const Standard_Real theVLast, const Standard_Real theTolU=0.0, const Standard_Real theTolV=0.0)
 Standard_ConstructionError is raised if UFirst>ULast or VFirst>VLast.
 
void Load (const Handle< Geom_Surface > &theSurf)
 
void Load (const Handle< Geom_Surface > &theSurf, const Standard_Real theUFirst, const Standard_Real theULast, const Standard_Real theVFirst, const Standard_Real theVLast, const Standard_Real theTolU=0.0, const Standard_Real theTolV=0.0)
 Standard_ConstructionError is raised if theUFirst>theULast or theVFirst>theVLast.
 
const Handle< Geom_Surface > & Surface () const
 
gp_Pnt Value (const Standard_Real U, const Standard_Real V) const override
 Computes the point of parameters U,V on the surface.
 
void D0 (const Standard_Real U, const Standard_Real V, gp_Pnt &P) const override
 Computes the point of parameters U,V on the surface.
 
void D1 (const Standard_Real U, const Standard_Real V, gp_Pnt &P, gp_Vec &D1U, gp_Vec &D1V) const override
 Computes the point and the first derivatives on the surface.
 
void D2 (const Standard_Real U, const Standard_Real V, gp_Pnt &P, gp_Vec &D1U, gp_Vec &D1V, gp_Vec &D2U, gp_Vec &D2V, gp_Vec &D2UV) const override
 Computes the point, the first and second derivatives on the surface.
 
void D3 (const Standard_Real U, const Standard_Real V, gp_Pnt &P, gp_Vec &D1U, gp_Vec &D1V, gp_Vec &D2U, gp_Vec &D2V, gp_Vec &D2UV, gp_Vec &D3U, gp_Vec &D3V, gp_Vec &D3UUV, gp_Vec &D3UVV) const override
 Computes the point, the first, second and third derivatives on the surface.
 
gp_Vec DN (const Standard_Real U, const Standard_Real V, const Standard_Integer Nu, const Standard_Integer Nv) const override
 Computes the derivative of order Nu in the direction U and Nv in the direction V at the point P(U, V).
 
Standard_Integer UDegree () const override
 
Standard_Integer NbUPoles () const override
 
Standard_Integer NbUKnots () const override
 
gp_Dir Direction () const override
 
Handle< Adaptor3d_SurfaceBasisSurface () const override
 
Standard_Real OffsetValue () const override
 
- Public Member Functions inherited from Adaptor3d_Surface
virtual ~Adaptor3d_Surface ()
 
- Public Member Functions inherited from Standard_Transient
 Standard_Transient ()
 Empty constructor.
 
 Standard_Transient (const Standard_Transient &)
 Copy constructor – does nothing.
 
Standard_Transientoperator= (const Standard_Transient &)
 Assignment operator, needed to avoid copying reference counter.
 
virtual ~Standard_Transient ()
 Destructor must be virtual.
 
virtual const opencascade::handle< Standard_Type > & DynamicType () const
 Returns a type descriptor about this object.
 
Standard_Boolean IsInstance (const opencascade::handle< Standard_Type > &theType) const
 Returns a true value if this is an instance of Type.
 
Standard_Boolean IsInstance (const Standard_CString theTypeName) const
 Returns a true value if this is an instance of TypeName.
 
Standard_Boolean IsKind (const opencascade::handle< Standard_Type > &theType) const
 Returns true if this is an instance of Type or an instance of any class that inherits from Type. Note that multiple inheritance is not supported by OCCT RTTI mechanism.
 
Standard_Boolean IsKind (const Standard_CString theTypeName) const
 Returns true if this is an instance of TypeName or an instance of any class that inherits from TypeName. Note that multiple inheritance is not supported by OCCT RTTI mechanism.
 
Standard_TransientThis () const
 Returns non-const pointer to this object (like const_cast). For protection against creating handle to objects allocated in stack or call from constructor, it will raise exception Standard_ProgramError if reference counter is zero.
 
Standard_Integer GetRefCount () const noexcept
 Get the reference counter of this object.
 
void IncrementRefCounter () noexcept
 Increments the reference counter of this object.
 
Standard_Integer DecrementRefCounter () noexcept
 Decrements the reference counter of this object; returns the decremented value.
 
virtual void Delete () const
 Memory deallocator for transient classes.
 

Additional Inherited Members

- Public Types inherited from Standard_Transient
typedef void base_type
 Returns a type descriptor about this object.
 
- Static Public Member Functions inherited from Standard_Transient
static constexpr const char * get_type_name ()
 Returns a type descriptor about this object.
 
static const opencascade::handle< Standard_Type > & get_type_descriptor ()
 Returns type descriptor of Standard_Transient class.
 
- Protected Attributes inherited from GeomAdaptor_Surface
Handle< Geom_SurfacemySurface
 
Standard_Real myUFirst
 
Standard_Real myULast
 
Standard_Real myVFirst
 
Standard_Real myVLast
 
Standard_Real myTolU
 
Standard_Real myTolV
 
Handle< Geom_BSplineSurfacemyBSplineSurface
 B-spline representation to prevent downcasts.
 
Handle< BSplSLib_CachemySurfaceCache
 Cached data for B-spline or Bezier surface.
 
GeomAbs_SurfaceType mySurfaceType
 
Handle< GeomEvaluator_SurfacemyNestedEvaluator
 Calculates values of nested complex surfaces (offset surface, surface of extrusion or revolution)
 

Detailed Description

This class defines a complete surface of revolution. The surface is obtained by rotating a curve a complete revolution about an axis. The curve and the axis must be in the same plane. If the curve and the axis are not in the same plane it is always possible to be in the previous case after a cylindrical projection of the curve in a referenced plane. For a complete surface of revolution the parametric range is 0 <= U <= 2*PI. – The parametric range for V is defined with the revolved curve. The origin of the U parametrization is given by the position of the revolved curve (reference). The direction of the revolution axis defines the positive sense of rotation (trigonometric sense) corresponding to the increasing of the parametric value U. The derivatives are always defined for the u direction. For the v direction the definition of the derivatives depends on the degree of continuity of the referenced curve.

Constructor & Destructor Documentation

◆ GeomAdaptor_SurfaceOfRevolution() [1/3]

GeomAdaptor_SurfaceOfRevolution::GeomAdaptor_SurfaceOfRevolution ( )

◆ GeomAdaptor_SurfaceOfRevolution() [2/3]

GeomAdaptor_SurfaceOfRevolution::GeomAdaptor_SurfaceOfRevolution ( const Handle< Adaptor3d_Curve > & C)

The Curve is loaded.

◆ GeomAdaptor_SurfaceOfRevolution() [3/3]

GeomAdaptor_SurfaceOfRevolution::GeomAdaptor_SurfaceOfRevolution ( const Handle< Adaptor3d_Curve > & C,
const gp_Ax1 & V )

The Curve and the Direction are loaded.

Member Function Documentation

◆ AxeOfRevolution()

gp_Ax1 GeomAdaptor_SurfaceOfRevolution::AxeOfRevolution ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ Axis()

const gp_Ax3 & GeomAdaptor_SurfaceOfRevolution::Axis ( ) const

◆ BasisCurve()

Handle< Adaptor3d_Curve > GeomAdaptor_SurfaceOfRevolution::BasisCurve ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ Bezier()

Handle< Geom_BezierSurface > GeomAdaptor_SurfaceOfRevolution::Bezier ( ) const
overridevirtual

This will NOT make a copy of the Bezier Surface : If you want to modify the Surface please make a copy yourself Also it will NOT trim the surface to myU/VFirst/Last.

Reimplemented from GeomAdaptor_Surface.

◆ BSpline()

Handle< Geom_BSplineSurface > GeomAdaptor_SurfaceOfRevolution::BSpline ( ) const
overridevirtual

This will NOT make a copy of the BSpline Surface : If you want to modify the Surface please make a copy yourself Also it will NOT trim the surface to myU/VFirst/Last.

Reimplemented from GeomAdaptor_Surface.

◆ Cone()

gp_Cone GeomAdaptor_SurfaceOfRevolution::Cone ( ) const
overridevirtual

Apex of the Cone = Cone.Position().Location() ==> ReferenceRadius = 0.

Reimplemented from GeomAdaptor_Surface.

◆ Cylinder()

gp_Cylinder GeomAdaptor_SurfaceOfRevolution::Cylinder ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ FirstUParameter()

Standard_Real GeomAdaptor_SurfaceOfRevolution::FirstUParameter ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ FirstVParameter()

Standard_Real GeomAdaptor_SurfaceOfRevolution::FirstVParameter ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ GetType()

GeomAbs_SurfaceType GeomAdaptor_SurfaceOfRevolution::GetType ( ) const
overridevirtual

Returns the type of the surface : Plane, Cylinder, Cone, Sphere, Torus, BezierSurface, BSplineSurface, SurfaceOfRevolution, SurfaceOfExtrusion, OtherSurface.

Reimplemented from GeomAdaptor_Surface.

◆ IsUClosed()

Standard_Boolean GeomAdaptor_SurfaceOfRevolution::IsUClosed ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ IsUPeriodic()

Standard_Boolean GeomAdaptor_SurfaceOfRevolution::IsUPeriodic ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ IsURational()

Standard_Boolean GeomAdaptor_SurfaceOfRevolution::IsURational ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ IsVClosed()

Standard_Boolean GeomAdaptor_SurfaceOfRevolution::IsVClosed ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ IsVPeriodic()

Standard_Boolean GeomAdaptor_SurfaceOfRevolution::IsVPeriodic ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ IsVRational()

Standard_Boolean GeomAdaptor_SurfaceOfRevolution::IsVRational ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ LastUParameter()

Standard_Real GeomAdaptor_SurfaceOfRevolution::LastUParameter ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ LastVParameter()

Standard_Real GeomAdaptor_SurfaceOfRevolution::LastVParameter ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ Load() [1/2]

void GeomAdaptor_SurfaceOfRevolution::Load ( const gp_Ax1 & V)

Changes the Direction.

◆ Load() [2/2]

void GeomAdaptor_SurfaceOfRevolution::Load ( const Handle< Adaptor3d_Curve > & C)

Changes the Curve.

◆ NbUIntervals()

Standard_Integer GeomAdaptor_SurfaceOfRevolution::NbUIntervals ( const GeomAbs_Shape S) const
overridevirtual

Returns the number of U intervals for continuity . May be one if UContinuity(me) >=

Reimplemented from GeomAdaptor_Surface.

◆ NbVIntervals()

Standard_Integer GeomAdaptor_SurfaceOfRevolution::NbVIntervals ( const GeomAbs_Shape S) const
overridevirtual

Returns the number of V intervals for continuity . May be one if VContinuity(me) >=

Reimplemented from GeomAdaptor_Surface.

◆ NbVKnots()

Standard_Integer GeomAdaptor_SurfaceOfRevolution::NbVKnots ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ NbVPoles()

Standard_Integer GeomAdaptor_SurfaceOfRevolution::NbVPoles ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ Plane()

gp_Pln GeomAdaptor_SurfaceOfRevolution::Plane ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ ShallowCopy()

virtual Handle< Adaptor3d_Surface > GeomAdaptor_SurfaceOfRevolution::ShallowCopy ( ) const
overridevirtual

Shallow copy of adaptor.

Reimplemented from GeomAdaptor_Surface.

◆ Sphere()

gp_Sphere GeomAdaptor_SurfaceOfRevolution::Sphere ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ Torus()

gp_Torus GeomAdaptor_SurfaceOfRevolution::Torus ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ UContinuity()

GeomAbs_Shape GeomAdaptor_SurfaceOfRevolution::UContinuity ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ UIntervals()

void GeomAdaptor_SurfaceOfRevolution::UIntervals ( TColStd_Array1OfReal & T,
const GeomAbs_Shape S ) const
overridevirtual

Returns the intervals with the requested continuity in the U direction.

Reimplemented from GeomAdaptor_Surface.

◆ UPeriod()

Standard_Real GeomAdaptor_SurfaceOfRevolution::UPeriod ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ UResolution()

Standard_Real GeomAdaptor_SurfaceOfRevolution::UResolution ( const Standard_Real R3d) const
overridevirtual

Returns the parametric U resolution corresponding to the real space resolution <R3d>.

Reimplemented from GeomAdaptor_Surface.

◆ UTrim()

Handle< Adaptor3d_Surface > GeomAdaptor_SurfaceOfRevolution::UTrim ( const Standard_Real First,
const Standard_Real Last,
const Standard_Real Tol ) const
overridevirtual

Returns a surface trimmed in the U direction equivalent of <me> between parameters <First> and <Last>. <Tol> is used to test for 3d points confusion. If <First> >= <Last>

Reimplemented from GeomAdaptor_Surface.

◆ VContinuity()

GeomAbs_Shape GeomAdaptor_SurfaceOfRevolution::VContinuity ( ) const
overridevirtual

Return CN.

Reimplemented from GeomAdaptor_Surface.

◆ VDegree()

Standard_Integer GeomAdaptor_SurfaceOfRevolution::VDegree ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ VIntervals()

void GeomAdaptor_SurfaceOfRevolution::VIntervals ( TColStd_Array1OfReal & T,
const GeomAbs_Shape S ) const
overridevirtual

Returns the intervals with the requested continuity in the V direction.

Reimplemented from GeomAdaptor_Surface.

◆ VPeriod()

Standard_Real GeomAdaptor_SurfaceOfRevolution::VPeriod ( ) const
overridevirtual

Reimplemented from GeomAdaptor_Surface.

◆ VResolution()

Standard_Real GeomAdaptor_SurfaceOfRevolution::VResolution ( const Standard_Real R3d) const
overridevirtual

Returns the parametric V resolution corresponding to the real space resolution <R3d>.

Reimplemented from GeomAdaptor_Surface.

◆ VTrim()

Handle< Adaptor3d_Surface > GeomAdaptor_SurfaceOfRevolution::VTrim ( const Standard_Real First,
const Standard_Real Last,
const Standard_Real Tol ) const
overridevirtual

Returns a surface trimmed in the V direction between parameters <First> and <Last>. <Tol> is used to test for 3d points confusion. If <First> >= <Last>

Reimplemented from GeomAdaptor_Surface.


The documentation for this class was generated from the following file: