X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_WidgetPoint2dDistance.h;h=0ad39f03cda875779d7f4c54de9eefb706db925e;hb=32208dedf0b2b5bd50b5b86c464f37a8e0eb07d0;hp=857212aca8288da21fb1a91118b9972402401da7;hpb=bc81a3b5bb8b7c51bdec9b32bd8db9c60a73fb88;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetPoint2dDistance.h b/src/PartSet/PartSet_WidgetPoint2dDistance.h index 857212aca..0ad39f03c 100644 --- a/src/PartSet/PartSet_WidgetPoint2dDistance.h +++ b/src/PartSet/PartSet_WidgetPoint2dDistance.h @@ -8,11 +8,12 @@ #define PartSet_WidgetPoint2dDistance_H #include "PartSet.h" -#include +#include "PartSet_MouseProcessor.h" + +#include #include -class PartSet_LockApplyMgr; class GeomAPI_Pnt2d; class ModuleBase_IWorkshop; class ModuleBase_IViewWindow; @@ -35,7 +36,8 @@ class QMouseEvent; * * \endcode */ -class PARTSET_EXPORT PartSet_WidgetPoint2dDistance : public ModuleBase_WidgetDoubleValue +class PARTSET_EXPORT PartSet_WidgetPoint2dDistance : public ModuleBase_WidgetLabelValue, + public PartSet_MouseProcessor { Q_OBJECT public: @@ -43,15 +45,15 @@ Q_OBJECT /// \param theParent the parent object /// \param theWorkshop a current workshop /// \param theData the widget configuation. The attribute of the model widget is obtained from - /// \param theParentId is Id of a parent of the current attribute - PartSet_WidgetPoint2dDistance(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop, - const Config_WidgetAPI* theData, - const std::string& theParentId); + PartSet_WidgetPoint2dDistance(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop, + const Config_WidgetAPI* theData); virtual ~PartSet_WidgetPoint2dDistance(); - /// The methiod called when widget is deactivated - virtual void deactivate(); + /// Checks if the selection presentation is valid in widget + /// \param theValue a selected presentation in the view + /// \return a boolean value + virtual bool isValidSelectionCustom(const std::shared_ptr& theValue); /// \returns the sketch instance CompositeFeaturePtr sketch() const { return mySketch; } @@ -62,23 +64,30 @@ Q_OBJECT /// Returns true if the event is processed. virtual bool processEnter(); -public slots: - /// Process of mouse move - /// \param theWnd a pointer to a window - /// \param theEvent a mouse event - void onMouseMove(ModuleBase_IViewWindow* theWnd, QMouseEvent* theEvent); + /// Processing the mouse move event in the viewer + /// \param theWindow a view window + /// \param theEvent a mouse event + virtual void mouseMoved(ModuleBase_IViewWindow* theWindow, QMouseEvent* theEvent); - protected slots: - /// Process of mouse release - /// \param theWnd a pointer to a window - /// \param theEvent a mouse event - void onMouseRelease(ModuleBase_IViewWindow* theWnd, QMouseEvent* theEvent); + /// Processing the mouse release event in the viewer + /// \param theWindow a view window + /// \param theEvent a mouse event + virtual void mouseReleased(ModuleBase_IViewWindow* theWindow, QMouseEvent* theEvent); protected: - /// The methiod called when widget is activated - virtual void activateCustom(); + /// Store current value in cashed value + void storeCurentValue(); + + /// Restore cashed value in the model attribute + /// \return boolean state if the restored feature shoud be hidden + bool restoreCurentValue(); - /// Set the second point which defines a value in the widget as a distance with a first point defined by feature + /// Fills the widget with default values + /// \return true if the widget current value is reset + virtual bool resetCustom(); + + /// Set the second point which defines a value in the widget as + /// a distance with a first point defined by feature void setPoint(FeaturePtr theFeature, const std::shared_ptr& thePnt); /// Compute the distance between points @@ -88,22 +97,23 @@ protected: virtual double computeValue(const std::shared_ptr& theFirstPnt, const std::shared_ptr& theCurrentPnt); -private slots: - /// Process values changed event - void onValuesChanged(); + /// Saves the internal parameters to the given feature + /// \return True in success + virtual bool storeValueCustom(); protected: /// A reference to workshop ModuleBase_IWorkshop* myWorkshop; - - /// A manager to lock/unlock Apply button in PP - PartSet_LockApplyMgr* myLockApplyMgr; /// A name of the first point std::string myFirstPntName; /// Reference to sketch CompositeFeaturePtr mySketch; + + bool myValueIsCashed; ///< boolean state if the value is cashed during value state change + bool myIsFeatureVisibleInCash; ///< boolean value if the feature was visible when cash if filled + double myValueInCash; ///< the cashed X value during value state change }; #endif