// This file is generated by WOK (CPPExt). // Please do not edit this file; modify original file instead. // The copyright and license terms as defined for the original file apply to // this header file considered to be the "object code" form of the original source. #ifndef _GC_MakeCylindricalSurface_HeaderFile #define _GC_MakeCylindricalSurface_HeaderFile #ifndef _Standard_HeaderFile #include #endif #ifndef _Standard_Macro_HeaderFile #include #endif #ifndef _Handle_Geom_CylindricalSurface_HeaderFile #include #endif #ifndef _GC_Root_HeaderFile #include #endif #ifndef _Standard_Real_HeaderFile #include #endif class Geom_CylindricalSurface; class StdFail_NotDone; class gp_Ax2; class gp_Cylinder; class gp_Pnt; class gp_Ax1; class gp_Circ; //! This class implements the following algorithms used
//! to create a CylindricalSurface from Geom.
//! * Create a CylindricalSurface parallel to another and
//! passing through a point.
//! * Create a CylindricalSurface parallel to another at a
//! distance
//! .
//! * Create a CylindricalSurface passing through 3 points.
//! * Create a CylindricalSurface by its axis and radius.
//! * Create a cylindricalSurface by its circular base.
//! 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.
class GC_MakeCylindricalSurface : public GC_Root { public: void* operator new(size_t,void* anAddress) { return anAddress; } void* operator new(size_t size) { return Standard::Allocate(size); } void operator delete(void *anAddress) { if (anAddress) Standard::Free((Standard_Address&)anAddress); } //! A2 defines the local coordinate system of the cylindrical surface.
//! The "ZDirection" of A2 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
//! Status is "NegativeRadius" if Radius < 0.0
Standard_EXPORT GC_MakeCylindricalSurface(const gp_Ax2& A2,const Standard_Real Radius); //! Creates a CylindricalSurface from a non persistent Cylinder
//! from package gp.
Standard_EXPORT GC_MakeCylindricalSurface(const gp_Cylinder& C); //! Make a CylindricalSurface from Geom
//! parallel to another
//! CylindricalSurface and passing through a
//! Pnt .
Standard_EXPORT GC_MakeCylindricalSurface(const gp_Cylinder& Cyl,const gp_Pnt& Point); //! Make a CylindricalSurface from Geom
//! parallel to another
//! CylindricalSurface at the distance
//! which can be greater or lower than zero.
//! The radius of the result is the absolute value of the
//! radius of plus
Standard_EXPORT GC_MakeCylindricalSurface(const gp_Cylinder& Cyl,const Standard_Real Dist); //! Make a CylindricalSurface from Geom
//! passing through 3 Pnt ,,.
//! Its axis is and its radius is the distance
//! between and
Standard_EXPORT GC_MakeCylindricalSurface(const gp_Pnt& P1,const gp_Pnt& P2,const gp_Pnt& P3); //! Make a CylindricalSurface by its axis and radius
//! .
Standard_EXPORT GC_MakeCylindricalSurface(const gp_Ax1& Axis,const Standard_Real Radius); //! Make a CylindricalSurface by its circular base.
Standard_EXPORT GC_MakeCylindricalSurface(const gp_Circ& Circ); //! Returns the constructed cylinder.
//! Exceptions StdFail_NotDone if no cylinder is constructed.
Standard_EXPORT const Handle_Geom_CylindricalSurface& Value() const; Standard_EXPORT const Handle_Geom_CylindricalSurface& Operator() const; Standard_EXPORT operator Handle_Geom_CylindricalSurface() const; protected: private: Handle_Geom_CylindricalSurface TheCylinder; }; // other Inline functions and methods (like "C++: function call" methods) #endif