Salome HOME
Save for a list of the local selected points.
[modules/hydro.git] / src / HYDROCurveCreator / CurveCreator_UtilsICurve.hxx
1 // Copyright (C) 2013  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Lesser General Public
5 // License as published by the Free Software Foundation; either
6 // version 2.1 of the License.
7 //
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11 // Lesser General Public License for more details.
12 //
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
16 //
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
18 //
19
20 #ifndef CURVECREATOR_UTILS_ICURVE_H
21 #define CURVECREATOR_UTILS_ICURVE_H
22
23 #include "CurveCreator_Macro.hxx"
24
25 #include "CurveCreator_ICurve.hxx"
26
27 #include <QMap>
28 #include <QList>
29
30 class CurveCreator_UtilsICurve
31 {
32 public:
33
34   /*!
35    * Returns a point index in the model curve by the point coordinates in the viewer
36    * \param theX the X coordinate of the point
37    * \param theY the Y coordinate of the point
38    */
39   CURVECREATOR_EXPORT static int  findLocalPointIndex( const CurveCreator_ICurve* theCurve,
40                                           int theSectionId, float theX, float theY );
41
42   CURVECREATOR_EXPORT static void findSectionsToPoints( const CurveCreator_ICurve* theCurve,
43                                           const double theX, const double theY,
44                                           CurveCreator_ICurve::SectionToPointList& thePoints );
45   CURVECREATOR_EXPORT static void convert( const CurveCreator_ICurve::SectionToPointList& thePoints,
46                                            QMap<int, QList<int> >& theConvPoints );
47
48   CURVECREATOR_EXPORT static void getPoint( const CurveCreator_ICurve* theCurve, const int theISection,
49                                             const int theIPoint, gp_Pnt& thePoint );
50
51   /*!
52    * Returns a unique section name
53    * \param theCurve a curve interface
54    */
55   CURVECREATOR_EXPORT static std::string getUniqSectionName(
56                                             CurveCreator_ICurve* theCurve );
57
58   /**
59    * Returns whethe the container has the value
60    * \param theList a container of values
61    * \param theValue a value
62    */
63   CURVECREATOR_EXPORT static bool contains( const CurveCreator_ICurve::SectionToPointList& theList,
64                                             const CurveCreator_ICurve::SectionToPoint& theValue );
65 };
66
67 #endif // CURVECREATOR_UTILS_ICURVE_H