// Created on: 1993-03-10 // Created by: JCV // Copyright (c) 1993-1999 Matra Datavision // Copyright (c) 1999-2014 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // // This library is free software; you can redistribute it and/or modify it under // the terms of the GNU Lesser General Public License version 2.1 as published // by the Free Software Foundation, with special exception defined in the file // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT // distribution for complete text of the license and disclaimer of any warranty. // // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. #ifndef _Geom_CylindricalSurface_HeaderFile #define _Geom_CylindricalSurface_HeaderFile #include #include #include #include #include #include class Standard_ConstructionError; class Standard_RangeError; class gp_Ax3; class gp_Cylinder; class gp_Trsf; class gp_GTrsf2d; class Geom_Curve; class gp_Pnt; class gp_Vec; class Geom_Geometry; class Geom_CylindricalSurface; DEFINE_STANDARD_HANDLE(Geom_CylindricalSurface, Geom_ElementarySurface) //! This class defines the infinite cylindrical surface. //! //! Every cylindrical surface is set by the following equation: //! S(U,V) = Location + R*cos(U)*XAxis + R*sin(U)*YAxis + V*ZAxis, //! where R is cylinder radius. //! //! The local coordinate system of the CylindricalSurface is defined //! with an axis placement (see class ElementarySurface). //! //! The "ZAxis" is the symmetry axis of the CylindricalSurface, //! it gives the direction of increasing parametric value V. //! //! The parametrization range is : //! U [0, 2*PI], V ]- infinite, + infinite[ //! //! The "XAxis" and the "YAxis" define the placement plane of the //! surface (Z = 0, and parametric value V = 0) perpendicular to //! the symmetry axis. The "XAxis" defines the origin of the //! parameter U = 0. The trigonometric sense gives the positive //! orientation for the parameter U. //! //! When you create a CylindricalSurface the U and V directions of //! parametrization are such that at each point of the surface the //! normal is oriented towards the "outside region". //! //! The methods UReverse VReverse change the orientation of the //! surface. class Geom_CylindricalSurface : public Geom_ElementarySurface { public: //! A3 defines the local coordinate system of the cylindrical surface. //! The "ZDirection" of A3 defines the direction of the surface's //! axis of symmetry. //! At the creation the parametrization of the surface is defined //! such that the normal Vector (N = D1U ^ D1V) is oriented towards //! the "outside region" of the surface. //! Warnings : //! It is not forbidden to create a cylindrical surface with //! Radius = 0.0 //! Raised if Radius < 0.0 Standard_EXPORT Geom_CylindricalSurface(const gp_Ax3& A3, const Standard_Real Radius); //! Creates a CylindricalSurface from a non transient Cylinder //! from package gp. Standard_EXPORT Geom_CylindricalSurface(const gp_Cylinder& C); //! Set so that has the same geometric properties as C. Standard_EXPORT void SetCylinder (const gp_Cylinder& C); //! Changes the radius of the cylinder. //! Raised if R < 0.0 Standard_EXPORT void SetRadius (const Standard_Real R); //! returns a non transient cylinder with the same geometric //! properties as . Standard_EXPORT gp_Cylinder Cylinder() const; //! Return the parameter on the Ureversed surface for //! the point of parameter U on . //! Return 2.PI - U. Standard_EXPORT Standard_Real UReversedParameter (const Standard_Real U) const Standard_OVERRIDE; //! Return the parameter on the Vreversed surface for //! the point of parameter V on . //! Return -V Standard_EXPORT Standard_Real VReversedParameter (const Standard_Real V) const Standard_OVERRIDE; //! Computes the parameters on the transformed surface for //! the transform of the point of parameters U,V on . //! me->Transformed(T)->Value(U',V') //! is the same point as //! me->Value(U,V).Transformed(T) //! Where U',V' are the new values of U,V after calling //! me->TranformParameters(U,V,T) //! This methods multiplies V by T.ScaleFactor() Standard_EXPORT virtual void TransformParameters (Standard_Real& U, Standard_Real& V, const gp_Trsf& T) const Standard_OVERRIDE; //! Returns a 2d transformation used to find the new //! parameters of a point on the transformed surface. //! me->Transformed(T)->Value(U',V') //! is the same point as //! me->Value(U,V).Transformed(T) //! Where U',V' are obtained by transforming U,V with //! th 2d transformation returned by //! me->ParametricTransformation(T) //! This methods returns a scale centered on the //! U axis with T.ScaleFactor Standard_EXPORT virtual gp_GTrsf2d ParametricTransformation (const gp_Trsf& T) const Standard_OVERRIDE; //! The CylindricalSurface is infinite in the V direction so //! V1 = Realfirst, V2 = RealLast from package Standard. //! U1 = 0 and U2 = 2*PI. Standard_EXPORT void Bounds (Standard_Real& U1, Standard_Real& U2, Standard_Real& V1, Standard_Real& V2) const Standard_OVERRIDE; //! Returns the coefficients of the implicit equation of the quadric //! in the absolute cartesian coordinate system : //! These coefficients are normalized. //! A1.X**2 + A2.Y**2 + A3.Z**2 + 2.(B1.X.Y + B2.X.Z + B3.Y.Z) + //! 2.(C1.X + C2.Y + C3.Z) + D = 0.0 Standard_EXPORT void Coefficients (Standard_Real& A1, Standard_Real& A2, Standard_Real& A3, Standard_Real& B1, Standard_Real& B2, Standard_Real& B3, Standard_Real& C1, Standard_Real& C2, Standard_Real& C3, Standard_Real& D) const; //! Returns the radius of this cylinder. Standard_EXPORT Standard_Real Radius() const; //! Returns True. Standard_EXPORT Standard_Boolean IsUClosed() const Standard_OVERRIDE; //! Returns False. Standard_EXPORT Standard_Boolean IsVClosed() const Standard_OVERRIDE; //! Returns True. Standard_EXPORT Standard_Boolean IsUPeriodic() const Standard_OVERRIDE; //! Returns False. Standard_EXPORT Standard_Boolean IsVPeriodic() const Standard_OVERRIDE; //! The UIso curve is a Line. The location point of this line is //! on the placement plane (XAxis, YAxis) of the surface. //! This line is parallel to the axis of symmetry of the surface. Standard_EXPORT Handle(Geom_Curve) UIso (const Standard_Real U) const Standard_OVERRIDE; //! The VIso curve is a circle. The start point of this circle //! (U = 0) is defined with the "XAxis" of the surface. //! The center of the circle is on the symmetry axis. Standard_EXPORT Handle(Geom_Curve) VIso (const Standard_Real V) const Standard_OVERRIDE; //! Computes the point P (U, V) on the surface. //! P (U, V) = Loc + Radius * (cos (U) * XDir + sin (U) * YDir) + //! V * ZDir //! where Loc is the origin of the placement plane (XAxis, YAxis) //! XDir is the direction of the XAxis and YDir the direction of //! the YAxis. Standard_EXPORT void D0 (const Standard_Real U, const Standard_Real V, gp_Pnt& P) const Standard_OVERRIDE; //! Computes the current point and the first derivatives in the //! directions U and V. Standard_EXPORT void D1 (const Standard_Real U, const Standard_Real V, gp_Pnt& P, gp_Vec& D1U, gp_Vec& D1V) const Standard_OVERRIDE; //! Computes the current point, the first and the second derivatives //! in the directions U and V. Standard_EXPORT 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 Standard_OVERRIDE; //! Computes the current point, the first, the second and the //! third derivatives in the directions U and V. Standard_EXPORT 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 Standard_OVERRIDE; //! Computes the derivative of order Nu in the direction u and Nv //! in the direction v. //! Raised if Nu + Nv < 1 or Nu < 0 or Nv < 0. Standard_EXPORT gp_Vec DN (const Standard_Real U, const Standard_Real V, const Standard_Integer Nu, const Standard_Integer Nv) const Standard_OVERRIDE; //! Applies the transformation T to this cylinder. Standard_EXPORT void Transform (const gp_Trsf& T) Standard_OVERRIDE; //! Creates a new object which is a copy of this cylinder. Standard_EXPORT Handle(Geom_Geometry) Copy() const Standard_OVERRIDE; DEFINE_STANDARD_RTTIEXT(Geom_CylindricalSurface,Geom_ElementarySurface) protected: private: Standard_Real radius; }; #endif // _Geom_CylindricalSurface_HeaderFile