X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROCurveCreator%2FCurveCreator_Utils.h;h=f7691c0dd78896b9f7bdfb2391d61a2701a63b73;hb=c363fc5c3541669e07cf4d991cc1e94253147ac1;hp=b81f4cf2bb9ff3ff96fc91d32162bdc0cf7cea0e;hpb=bc94f7ba1f12d74aee550ceae01684f1438bd8ac;p=modules%2Fhydro.git diff --git a/src/HYDROCurveCreator/CurveCreator_Utils.h b/src/HYDROCurveCreator/CurveCreator_Utils.h index b81f4cf2..f7691c0d 100644 --- a/src/HYDROCurveCreator/CurveCreator_Utils.h +++ b/src/HYDROCurveCreator/CurveCreator_Utils.h @@ -21,6 +21,7 @@ #define CURVECREATOR_UTILS_H #include "CurveCreator_Macro.hxx" +#include "CurveCreator_ICurve.hxx" #include #include // TODO: remove @@ -32,7 +33,6 @@ #include #include // TODO: remove -class CurveCreator_ICurve; class CurveCreator_Utils { @@ -62,57 +62,45 @@ public: Handle(V3d_View) theView ); /** - * Generates shape on the curve with a fixed section index + * Generates shape on the curve * \param theCurve a curve object, that contains data - * \param theISection a curve section index * \param theShape a generated shape */ CURVECREATOR_EXPORT static void constructShape( const CurveCreator_ICurve* theCurve, - const int theISection, - TopoDS_Shape& theShape, - std::vector& theAdditional ); + TopoDS_Shape& theShape ); /** - * Generates shape on the curve + * Find selected points in the context + * \param theContext the viewer context * \param theCurve a curve object, that contains data - * \param theShape a generated shape */ - CURVECREATOR_EXPORT static void constructShape( const CurveCreator_ICurve* theCurve, - TopoDS_Shape& theShape ); + CURVECREATOR_EXPORT static void getSelectedPoints( Handle(AIS_InteractiveContext) theContext, + const CurveCreator_ICurve* theCurve, + CurveCreator_ICurve::SectionToPointList& thePoints ); /** - * Find selected points in the context + * Set selected points to the context * \param theContext the viewer context + * \param theCurve a curve object, that contains data + * \param thePoints the curve point indices to be selected in the context */ - CURVECREATOR_EXPORT static std::list getSelectedPoints( - Handle(AIS_InteractiveContext) theContext ); + CURVECREATOR_EXPORT static void setSelectedPoints( + Handle(AIS_InteractiveContext) theContext, + const CurveCreator_ICurve* theCurve, + const CurveCreator_ICurve::SectionToPointList& thePoints = + CurveCreator_ICurve::SectionToPointList() ); /*! * \brief Sets the local point context for the 3D viewer. + * \param theCurve a curve object, that contains data + * \param theContext the viewer context * \param theOpen The flag to open or close the local context. */ CURVECREATOR_EXPORT static void setLocalPointContext( + const CurveCreator_ICurve* theCurve, Handle(AIS_InteractiveContext) theContext, const bool theOpen ); - /** - * Find the neighbour points by the clicked coordinates - * \param theContext the viewer context. - * \param theContext the V3D view. - * \param theX the X coordinate in the view. - * \param theY the Y coordinate in the view. - * \param thePoint the output point to be append to the model curve - * \param thePoint1 the output point to bound the line where a new point should be inserted - * \param thePoint2 the output point to bound the line where a new point should be inserted - */ - CURVECREATOR_EXPORT static bool getNeighbourPoints( - Handle(AIS_InteractiveContext) theContext, - Handle(V3d_View) theView, - const int theX, const int theY, - gp_Pnt& thePoint, gp_Pnt& thePoint1, - gp_Pnt& thePoint2 ); - -protected: /** * Checks whether the point belongs to the OCC object * \param theObject a line or shape with a bspline inside @@ -128,6 +116,7 @@ protected: gp_Pnt& thePoint, gp_Pnt& thePoint1, gp_Pnt& thePoint2 ); +protected: /* * Returns whether the clicked point belong to the curve or has a very near projection * \param theX the X coordinate of a point clicked in the OCC viewer @@ -139,7 +128,22 @@ protected: Handle(V3d_View) theView, const int theX, const int theY, const Handle(Geom_Curve)& theCurve, - Standard_Real& theParameter ); + Standard_Real& theParameter, + int& theDelta ); + + /* + * Returns whether the X and Y coordinates is in the pixel tolerance + * \param theX the X coordinate of the first point + * \param theY the Y coordinate of the first point + * \param theOtherX the X coordinate of the second point + * \param theOtherY the Y coordinate of the second point + * \param theTolerance the tolerance to compare + * \param theDelta the sum of the a square of X and a square of Y + * \returns whether the points are provide to the pixel tolerance + */ + CURVECREATOR_EXPORT static bool isEqualPixels( const int theX, const int theY, + const int theOtherX, const int theOtherY, + const double theTolerance, int& theDelta ); };