Salome HOME
Internal issue 0022865: Restructurization of Partition packages.
[modules/geom.git] / src / GEOMAlgo_NEW / GEOMAlgo_SurfaceTools.hxx
1 // Copyright (C) 2007-2011  CEA/DEN, EDF R&D, OPEN CASCADE\r
2 //\r
3 // Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,\r
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS\r
5 //\r
6 // This library is free software; you can redistribute it and/or\r
7 // modify it under the terms of the GNU Lesser General Public\r
8 // License as published by the Free Software Foundation; either\r
9 // version 2.1 of the License.\r
10 //\r
11 // This library is distributed in the hope that it will be useful,\r
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU\r
14 // Lesser General Public License for more details.\r
15 //\r
16 // You should have received a copy of the GNU Lesser General Public\r
17 // License along with this library; if not, write to the Free Software\r
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA\r
19 //\r
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com\r
21 //\r
22 \r
23 // File:        GEOMAlgo_SurfaceTools.hxx\r
24 // Created:     Thu Jan 27 11:05:16 2005\r
25 // Author:      Peter KURNEV\r
26 //              <pkv@irinox>\r
27 //\r
28 #ifndef _GEOMAlgo_SurfaceTools_HeaderFile\r
29 #define _GEOMAlgo_SurfaceTools_HeaderFile\r
30 \r
31 #include <Standard.hxx>\r
32 #include <Standard_Macro.hxx>\r
33 #include <Standard_Boolean.hxx>\r
34 #include <Handle_Geom_Surface.hxx>\r
35 #include <Standard_Real.hxx>\r
36 #include <TopAbs_State.hxx>\r
37 #include <GEOMAlgo_State.hxx>\r
38 #include <Standard_Integer.hxx>\r
39 #include <Geom_Surface.hxx>\r
40 #include <gp_Pnt.hxx>\r
41 #include <gp_Cylinder.hxx>\r
42 #include <GeomAdaptor_Surface.hxx>\r
43 #include <gp_Pln.hxx>\r
44 #include <gp_Sphere.hxx>\r
45 \r
46 \r
47 //=======================================================================\r
48 //function : GEOMAlgo_SurfaceTools\r
49 //purpose  : \r
50 //=======================================================================\r
51 class GEOMAlgo_SurfaceTools  \r
52 {\r
53  public:\r
54   Standard_EXPORT\r
55     static  Standard_Boolean IsAnalytic(const Handle(Geom_Surface)& aS) ;\r
56   \r
57   Standard_EXPORT\r
58     static  Standard_Boolean IsCoaxial(const gp_Pnt& aP1,\r
59                                        const gp_Pnt& aP2,\r
60                                        const gp_Cylinder& aCyl,\r
61                                        const Standard_Real aTol) ;\r
62   \r
63   Standard_EXPORT\r
64     static  Standard_Boolean IsConformState(const TopAbs_State aST1,\r
65                                             const GEOMAlgo_State aST2) ;\r
66   \r
67   Standard_EXPORT\r
68     static  Standard_Integer GetState(const gp_Pnt& aP,\r
69                                       const GeomAdaptor_Surface& aS,\r
70                                       const Standard_Real aTol,TopAbs_State& aSt) ;\r
71   \r
72   Standard_EXPORT\r
73     static  Standard_Integer GetState(const gp_Pnt& aP,\r
74                                       const Handle(Geom_Surface)& aS,\r
75                                       const Standard_Real aTol,\r
76                                       TopAbs_State& aSt) ;\r
77   \r
78   Standard_EXPORT\r
79     static  Standard_Real Distance(const gp_Pnt& aP,\r
80                                    const gp_Pln& aPln) ;\r
81   \r
82   Standard_EXPORT\r
83     static  Standard_Real Distance(const gp_Pnt& aP,\r
84                                    const gp_Cylinder& aCyl) ;\r
85   \r
86   Standard_EXPORT   \r
87     static  Standard_Real Distance(const gp_Pnt& aP,\r
88                                    const gp_Sphere& aSph) ;\r
89   \r
90   Standard_EXPORT\r
91     static  TopAbs_State ReverseState(const TopAbs_State aSt) ;\r
92 \r
93 };\r
94 #endif\r