Version: 9.12.0
GEOM_ICanonicalRecognition_i.hh
Go to the documentation of this file.
1 // Copyright (C) 2007-2023 CEA, EDF, 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 
35 
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,
44 
48  CORBA::Boolean isPlane(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
49  GEOM::ListOfDouble& theNormal, GEOM::ListOfDouble& theOrigin);
50 
54  CORBA::Boolean isSphere(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
55  GEOM::ListOfDouble& theOrigin, CORBA::Double& theRadius);
56 
60  CORBA::Boolean isCone(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
61  GEOM::ListOfDouble& theAxis, GEOM::ListOfDouble& theApex,
62  CORBA::Double& theHalfAngle);
63 
67  CORBA::Boolean isCylinder(GEOM::GEOM_Object_ptr theShape, CORBA::Double theTolerance,
68  GEOM::ListOfDouble& theAxis, GEOM::ListOfDouble& theOrigin,
69  CORBA::Double& theRadius);
70 
74  CORBA::Boolean isLine(GEOM::GEOM_Object_ptr theEdge, CORBA::Double theTolerance,
75  GEOM::ListOfDouble& theDir, GEOM::ListOfDouble& theOrigin);
76 
80  CORBA::Boolean isCircle(GEOM::GEOM_Object_ptr theEdge, CORBA::Double theTolerance,
81  GEOM::ListOfDouble& theNormal, GEOM::ListOfDouble& theOrigin,
82  CORBA::Double& theRadius);
83 
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 
93  { return (::GEOMImpl_ICanonicalRecognition*)GetImpl(); }
94 };
95 
96 #endif
#define GEOM_I_EXPORT
Definition: GEOM_GEOM_I.hxx:33
static Standard_Boolean isCircle(const TopoDS_Edge theEdge)
Definition: ShHealOper_FillHoles.cxx:202
Definition: GEOMImpl_ICanonicalRecognition.hxx:45
Definition: GEOM_ICanonicalRecognition_i.hh:39
::GEOMImpl_ICanonicalRecognition * GetOperation()
Definition: GEOM_ICanonicalRecognition_i.hh:92
Definition: GEOM_IOperations_i.hh:37
::GEOM_IOperations * GetImpl()
Definition: GEOM_IOperations_i.hh:60
sequence< double > ListOfDouble
Definition: GEOM_Gen.idl:257