1 // Copyright (C) 2007-2012 CEA/DEN, EDF R&D, 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.
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
22 #ifndef _GEOMImpl_ICurvesOperations_HXX_
23 #define _GEOMImpl_ICurvesOperations_HXX_
25 #include "GEOM_IOperations.hxx"
27 #include <TCollection_AsciiString.hxx>
32 class Handle(GEOM_Object);
34 class GEOMImpl_ICurvesOperations : public GEOM_IOperations {
38 enum CurveType { Polyline, Bezier, Interpolation };
40 Standard_EXPORT GEOMImpl_ICurvesOperations(GEOM_Engine* theEngine, int theDocID);
41 Standard_EXPORT ~GEOMImpl_ICurvesOperations();
43 Standard_EXPORT Handle(GEOM_Object) MakeCircleThreePnt (Handle(GEOM_Object) thePnt1,
44 Handle(GEOM_Object) thePnt2,
45 Handle(GEOM_Object) thePnt3);
46 Standard_EXPORT Handle(GEOM_Object) MakeCircleCenter2Pnt (Handle(GEOM_Object) thePnt1,
47 Handle(GEOM_Object) thePnt2,
48 Handle(GEOM_Object) thePnt3);
49 Standard_EXPORT Handle(GEOM_Object) MakeCirclePntVecR (Handle(GEOM_Object) thePnt,
50 Handle(GEOM_Object) theVec, double theR);
52 Standard_EXPORT Handle(GEOM_Object) MakeEllipse (Handle(GEOM_Object) thePnt,
53 Handle(GEOM_Object) theVec,
54 double theRMajor, double theRMinor,
55 Handle(GEOM_Object) theVecMaj);
57 Standard_EXPORT Handle(GEOM_Object) MakeArc (Handle(GEOM_Object) thePnt1,
58 Handle(GEOM_Object) thePnt2,
59 Handle(GEOM_Object) thePnt3);
61 Standard_EXPORT Handle(GEOM_Object) MakeArcCenter (Handle(GEOM_Object) thePnt1,
62 Handle(GEOM_Object) thePnt2,
63 Handle(GEOM_Object) thePnt3,
66 Standard_EXPORT Handle(GEOM_Object) MakeArcOfEllipse (Handle(GEOM_Object) thePnt1,
67 Handle(GEOM_Object) thePnt2,
68 Handle(GEOM_Object) thePnt3);
70 Standard_EXPORT Handle(GEOM_Object) MakePolyline (std::list<Handle(GEOM_Object)> thePoints,
71 bool theIsClosed = false);
73 Standard_EXPORT Handle(GEOM_Object) MakeSplineBezier (std::list<Handle(GEOM_Object)> thePoints,
74 bool theIsClosed = false);
76 Standard_EXPORT Handle(GEOM_Object) MakeSplineInterpolation (std::list<Handle(GEOM_Object)> thePoints,
77 bool theIsClosed = false,
78 bool theDoReordering = false);
80 Standard_EXPORT Handle(GEOM_Object) MakeSplineInterpolWithTangents
81 (std::list<Handle(GEOM_Object)> thePoints,
82 Handle(GEOM_Object) theFirstVec,
83 Handle(GEOM_Object) theLastVec);
85 Standard_EXPORT Handle(GEOM_Object) MakeCurveParametric
86 (const char* thexExpr, const char* theyExpr, const char* thezExpr,
87 double theParamMin, double theParamMax, double theParamStep,
88 CurveType theCurveType, int theParamNbStep=0, bool theNewMethod=false);
90 Standard_EXPORT Handle(GEOM_Object) MakeSketcher (const char* theCommand,
91 std::list<double> theWorkingPlane);
92 Standard_EXPORT Handle(GEOM_Object) MakeSketcherOnPlane (const char* theCommand,
93 Handle(GEOM_Object) theWorkingPlane);
94 Standard_EXPORT Handle(GEOM_Object) Make3DSketcherCommand (const char* theCommand);
95 Standard_EXPORT Handle(GEOM_Object) Make3DSketcher (std::list<double> theCoordinates);