Salome HOME
bos #29469: Advanced geometry features: Detect type of shape
[modules/geom.git] / src / GEOM_I / GEOM_ICanonicalRecognition_i.hh
1 // Copyright (C) 2007-2022  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 // Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License, or (at your option) any later version.
10 //
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 // Lesser General Public License for more details.
15 //
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
19 //
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22
23 #ifndef _GEOM_ICanonicalRecognition_i_HeaderFile
24 #define _GEOM_ICanonicalRecognition_i_HeaderFile
25
26 #include "GEOMImpl_Gen.hxx"
27
28 #include <SALOMEconfig.h>
29
30 #include CORBA_SERVER_HEADER(GEOM_Gen)
31 #include "GEOM_IOperations_i.hh"
32 #include "GEOM_Object_i.hh"
33
34 #include "GEOMImpl_ICanonicalRecognition.hxx"
35
36 class GEOM_I_EXPORT GEOM_ICanonicalRecognition_i :
37   public virtual POA_GEOM::GEOM_ICanonicalRecognition,
38   public virtual GEOM_IOperations_i
39 {
40  public:
41   GEOM_ICanonicalRecognition_i (PortableServer::POA_ptr thePOA, GEOM::GEOM_Gen_ptr theEngine,
42                            ::GEOMImpl_ICanonicalRecognition* theImpl);
43   ~GEOM_ICanonicalRecognition_i();
44
45   /*!
46    *  \brief Check if the shape is planar
47    */
48   CORBA::Boolean isPlane(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
49     GEOM::ListOfDouble& theNormal, GEOM::ListOfDouble& theOrigin);
50
51   /*!
52    * \brief Check if shape is spherical
53    */
54   CORBA::Boolean isSphere(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
55     GEOM::ListOfDouble& theOrigin, CORBA::Double& theRadius);
56
57   /*!
58    * \brief Check if shape is conical
59    */
60   CORBA::Boolean isCone(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
61     GEOM::ListOfDouble& theAxis, GEOM::ListOfDouble& theApex,
62     CORBA::Double& theHalfAngle);
63
64   /*!
65    * \brief Check if shape is cylinder
66    */
67   CORBA::Boolean isCylinder(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
68     GEOM::ListOfDouble& theAxis, GEOM::ListOfDouble& theOrigin,
69     CORBA::Double& theRadius);
70
71   /*!
72    * \brief Check if edge / wire is line
73    */
74   CORBA::Boolean isLine(GEOM::GEOM_Object_ptr theEdge, CORBA::Double theTolerance,
75     GEOM::ListOfDouble& theDir, GEOM::ListOfDouble& theOrigin);
76
77   /*!
78    * \brief Check if edge / wire is circle
79    */
80   CORBA::Boolean isCircle(GEOM::GEOM_Object_ptr theEdge, CORBA::Double theTolerance,
81     GEOM::ListOfDouble& theNormal, GEOM::ListOfDouble& theOrigin,
82     CORBA::Double& theRadius);
83
84   /*!
85    * \brief Check if edge / wire is ellipse
86    */
87   CORBA::Boolean isEllipse(GEOM::GEOM_Object_ptr theEdge, CORBA::Double theTolerance,
88     GEOM::ListOfDouble& theNormal, GEOM::ListOfDouble& theDirX,
89     GEOM::ListOfDouble& theOrigin,
90     CORBA::Double& theMajorRadius, CORBA::Double& theMinorRadius);
91
92   ::GEOMImpl_ICanonicalRecognition* GetOperation()
93   { return (::GEOMImpl_ICanonicalRecognition*)GetImpl(); }
94 };
95
96 #endif