1 // Copyright (C) 2007-2023 CEA, EDF, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
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.
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.
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
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
23 #ifndef _GEOM_ICanonicalRecognition_i_HeaderFile
24 #define _GEOM_ICanonicalRecognition_i_HeaderFile
26 #include "GEOMImpl_Gen.hxx"
28 #include <SALOMEconfig.h>
30 #include CORBA_SERVER_HEADER(GEOM_Gen)
31 #include "GEOM_IOperations_i.hh"
32 #include "GEOM_Object_i.hh"
34 #include "GEOMImpl_ICanonicalRecognition.hxx"
36 class GEOM_I_EXPORT GEOM_ICanonicalRecognition_i :
37 public virtual POA_GEOM::GEOM_ICanonicalRecognition,
38 public virtual GEOM_IOperations_i
41 GEOM_ICanonicalRecognition_i (PortableServer::POA_ptr thePOA, GEOM::GEOM_Gen_ptr theEngine,
42 ::GEOMImpl_ICanonicalRecognition* theImpl);
43 ~GEOM_ICanonicalRecognition_i();
46 * \brief Check if the shape is planar
48 CORBA::Boolean isPlane(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
49 GEOM::ListOfDouble& theNormal, GEOM::ListOfDouble& theOrigin);
52 * \brief Check if shape is spherical
54 CORBA::Boolean isSphere(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
55 GEOM::ListOfDouble& theOrigin, CORBA::Double& theRadius);
58 * \brief Check if shape is conical
60 CORBA::Boolean isCone(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
61 GEOM::ListOfDouble& theAxis, GEOM::ListOfDouble& theApex,
62 CORBA::Double& theHalfAngle);
65 * \brief Check if shape is cylinder
67 CORBA::Boolean isCylinder(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
68 GEOM::ListOfDouble& theAxis, GEOM::ListOfDouble& theOrigin,
69 CORBA::Double& theRadius);
72 * \brief Check if edge / wire is line
74 CORBA::Boolean isLine(GEOM::GEOM_Object_ptr theEdge, CORBA::Double theTolerance,
75 GEOM::ListOfDouble& theDir, GEOM::ListOfDouble& theOrigin);
78 * \brief Check if edge / wire is circle
80 CORBA::Boolean isCircle(GEOM::GEOM_Object_ptr theEdge, CORBA::Double theTolerance,
81 GEOM::ListOfDouble& theNormal, GEOM::ListOfDouble& theOrigin,
82 CORBA::Double& theRadius);
85 * \brief Check if edge / wire is ellipse
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);
92 ::GEOMImpl_ICanonicalRecognition* GetOperation()
93 { return (::GEOMImpl_ICanonicalRecognition*)GetImpl(); }