X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_WidgetSketchLabel.h;h=2bc8d85d682d04865b9e815d9adbdced64400b2f;hb=7d182041b78ddb4375098cff6042edc8817f540c;hp=ab7cd18eb35737396accc48f7e5b4be2a0cb4471;hpb=a90ab0e7171b2dfab838fbc066c2f20217c49c03;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetSketchLabel.h b/src/PartSet/PartSet_WidgetSketchLabel.h index ab7cd18eb..2bc8d85d6 100644 --- a/src/PartSet/PartSet_WidgetSketchLabel.h +++ b/src/PartSet/PartSet_WidgetSketchLabel.h @@ -19,7 +19,6 @@ #include class QLabel; -//class QTimer; class XGUI_OperationMgr; class XGUI_Workshop; class QCheckBox; @@ -43,15 +42,19 @@ Q_OBJECT /// \param theParent the parent object /// \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_WidgetSketchLabel(QWidget* theParent, const Config_WidgetAPI* theData, + PartSet_WidgetSketchLabel(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop, + const Config_WidgetAPI* theData, const std::string& theParentId, bool toShowConstraints); virtual ~PartSet_WidgetSketchLabel(); - virtual bool restoreValue() - { - return true; - } + /// Set the given wrapped value to the current widget + /// This value should be processed in the widget according to the needs + /// The method is called by the current operation to process the operation preselection. + /// It is redefined to do nothing if the plane of the sketch has been already set. + /// \param theValues the wrapped selection values + virtual bool setSelection(QList& theValues, + const bool theToValidate); /// Returns list of widget controls /// \return a control list @@ -60,13 +63,6 @@ Q_OBJECT /// The methiod called when widget is deactivated virtual void deactivate(); - /// Returns pointer to workshop - XGUI_Workshop* workshop() const { return myWorkshop; } - - /// Set pointer to workshop - /// \param theWork a pointer to workshop - void setWorkshop(XGUI_Workshop* theWork) { myWorkshop = theWork; } - /// Returns sketcher plane std::shared_ptr plane() const; @@ -106,16 +102,26 @@ protected: return true; } + virtual bool restoreValueCustom() + { + return true; + } + /// The methiod called when widget is activated virtual void activateCustom(); + /// Erase preview planes, disconnect widget, change the view projection + /// \param thePrs a selected presentation + void updateByPlaneSelected(const ModuleBase_ViewerPrs& thePrs); + + protected: + /// Activate or deactivate selection + void activateSelection(bool toActivate); + private slots: /// Slot on change selection void onSelectionChanged(); - /// Set sketch specific mode of selection - //void setSketchingMode(); - private: /// Create preview of planes for sketch plane selection /// \param theOrigin an origin of the plane @@ -125,6 +131,9 @@ protected: std::shared_ptr theNorm, const int theRGB[3]); + //! Returns workshop + XGUI_Workshop* workshop() const; + /// Set sketch plane by shape /// \param theShape a planar face std::shared_ptr setSketchPlane(const TopoDS_Shape& theShape); @@ -140,15 +149,11 @@ protected: QString myText; QString myTooltip; - XGUI_Workshop* myWorkshop; - AISObjectPtr myYZPlane; AISObjectPtr myXZPlane; AISObjectPtr myXYPlane; bool myPreviewDisplayed; - //QTimer* mySelectionTimer; - QCheckBox* myShowConstraints; };