// Created on: 1992-09-28 // Created by: Remi GILET // Copyright (c) 1992-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 _GC_MakeConicalSurface_HeaderFile #define _GC_MakeConicalSurface_HeaderFile #include #include #include #include #include class gp_Ax2; class gp_Cone; class gp_Pnt; //! This class implements the following algorithms used //! to create a ConicalSurface from Geom. //! * Create a ConicalSurface parallel to another and passing //! through a point. //! * Create a ConicalSurface parallel to another at a distance //! . //! * Create a ConicalSurface by 4 points. //! * Create a ConicalSurface by its axis and 2 points. //! * Create a ConicalSurface by 2 points and 2 radius. //! The local coordinate system of the ConicalSurface is defined //! with an axis placement (see class ElementarySurface). //! //! The "ZAxis" is the symmetry axis of the ConicalSurface, //! it gives the direction of increasing parametric value V. //! The apex of the surface is on the negative side of this axis. //! //! 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 ConicalSurface the U and V directions of //! parametrization are such that at each point of the surface the //! normal is oriented towards the "outside region". class GC_MakeConicalSurface : public GC_Root { public: DEFINE_STANDARD_ALLOC //! A2 defines the local coordinate system of the conical surface. //! Ang is the conical surface semi-angle ]0, PI/2[. //! Radius is the radius of the circle Viso in the placement plane //! of the conical surface defined with "XAxis" and "YAxis". //! The "ZDirection" of A2 defines the direction of the surface's //! axis of symmetry. //! If the location point of A2 is the apex of the surface //! Radius = 0 . //! 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. //! Status is "NegativeRadius" if Radius < 0.0 or "BadAngle" if //! Ang < Resolution from gp or Ang >= PI/ - Resolution Standard_EXPORT GC_MakeConicalSurface(const gp_Ax2& A2, const Standard_Real Ang, const Standard_Real Radius); //! Creates a ConicalSurface from a non persistent Cone from package gp. Standard_EXPORT GC_MakeConicalSurface(const gp_Cone& C); //! Make a ConicalSurface from Geom passing through 3 //! Pnt ,,. //! Its axis is and the radius of its base is //! the distance between and . //! The distance between and is the radius of //! the section passing through . //! An error iss raised if ,,, are //! colinear or if is perpendicular to or //! is colinear to . Standard_EXPORT GC_MakeConicalSurface(const gp_Pnt& P1, const gp_Pnt& P2, const gp_Pnt& P3, const gp_Pnt& P4); //! Make a ConicalSurface with two points and two radius. //! The axis of the solution is the line passing through //! and . //! is the radius of the section passing through //! and the radius of the section passing through . Standard_EXPORT GC_MakeConicalSurface(const gp_Pnt& P1, const gp_Pnt& P2, const Standard_Real R1, const Standard_Real R2); //! Returns the constructed cone. //! Exceptions //! StdFail_NotDone if no cone is constructed. Standard_EXPORT const Handle(Geom_ConicalSurface)& Value() const; operator const Handle(Geom_ConicalSurface)& () const { return Value(); } private: Handle(Geom_ConicalSurface) TheCone; }; #endif // _GC_MakeConicalSurface_HeaderFile