1 // Copyright (C) 2013 CEA/DEN, EDF R&D, OPEN CASCADE
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.
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.
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
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
20 #ifndef CURVECREATOR_UTILS_H
21 #define CURVECREATOR_UTILS_H
23 #include "CurveCreator_Macro.hxx"
25 #include <AIS_InteractiveContext.hxx>
26 #include <V3d_View.hxx>
28 #include <Geom_Curve.hxx>
32 class CurveCreator_Utils
37 * \brief Returns the point clicked in 3D view.
39 * \param x The X coordinate in the view.
40 * \param y The Y coordinate in the view.
41 * \param theView View where the given point takes place.
42 * \retval gp_Pnt Returns the point clicked in 3D view
44 CURVECREATOR_EXPORT static void ConvertPointToClick( const gp_Pnt& thePoint,
45 Handle(V3d_View) theView,
49 * \brief Returns the point clicked in 3D view.
51 * \param x The X coordinate in the view.
52 * \param y The Y coordinate in the view.
53 * \param theView View where the given point takes place.
54 * \retval gp_Pnt Returns the point clicked in 3D view
56 CURVECREATOR_EXPORT static gp_Pnt ConvertClickToPoint( int x, int y,
57 Handle(V3d_View) theView );
60 * Find selected points in the context
61 * \param theContext the viewer context
63 CURVECREATOR_EXPORT static std::list<float> getSelectedPoints(
64 Handle(AIS_InteractiveContext) theContext );
67 * \brief Sets the local point context for the 3D viewer.
68 * \param theOpen The flag to open or close the local context.
70 CURVECREATOR_EXPORT static void setLocalPointContext(
71 Handle(AIS_InteractiveContext) theContext,
75 * Find the neighbour points by the clicked coordinates
76 * \param theContext the viewer context.
77 * \param theContext the V3D view.
78 * \param theX the X coordinate in the view.
79 * \param theY the Y coordinate in the view.
80 * \param thePoint the output point to be append to the model curve
81 * \param thePoint1 the output point to bound the line where a new point should be inserted
82 * \param thePoint2 the output point to bound the line where a new point should be inserted
84 CURVECREATOR_EXPORT static bool getNeighbourPoints(
85 Handle(AIS_InteractiveContext) theContext,
86 Handle(V3d_View) theView,
87 const int theX, const int theY,
88 gp_Pnt& thePoint, gp_Pnt& thePoint1,
91 * Checks whether the point belongs to the OCC object
92 * \param theObject a line or shape with a bspline inside
93 * \param theX the X coordinate in the view.
94 * \param theY the Y coordinate in the view.
95 * \param thePoint the output point to be append to the model curve
96 * \param thePoint1 the output point to bound the line where a new point should be inserted
97 * \param thePoint2 the output point to bound the line where a new point should be inserted
99 CURVECREATOR_EXPORT static bool pointOnObject( Handle(V3d_View) theView,
100 Handle(AIS_InteractiveObject) theObject,
101 const int theX, const int theY,
102 gp_Pnt& thePoint, gp_Pnt& thePoint1,
106 * Returns whether the clicked point belong to the curve or has a very near projection
107 * \param theX the X coordinate of a point clicked in the OCC viewer
108 * \param theY the Y coordinate of a point clicked in the OCC viewer
109 * \param theCurve a geometry curve
110 * \param theOutPoint a found projected point on the curve
112 CURVECREATOR_EXPORT static bool hasProjectPointOnCurve(
113 Handle(V3d_View) theView,
114 const int theX, const int theY,
115 const Handle(Geom_Curve)& theCurve,
116 Standard_Real& theParameter );
120 #endif // CURVECREATOR_UTILS_H