X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_WidgetSketchLabel.h;h=600147ed4c87cada0beb8376c5b2fb9133c8de58;hb=031179ada6681b874314c450eeda806f9f8abd28;hp=8288bdf82ac54d8248693eaa42f5c28682cc668f;hpb=5ba89a77cdb9638a6d298c2aa5233d26576d9ed0;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetSketchLabel.h b/src/PartSet/PartSet_WidgetSketchLabel.h index 8288bdf82..600147ed4 100644 --- a/src/PartSet/PartSet_WidgetSketchLabel.h +++ b/src/PartSet/PartSet_WidgetSketchLabel.h @@ -9,20 +9,24 @@ #include "PartSet.h" -#include +#include "PartSet_Tools.h" + +#include #include #include #include #include -#include #include +#include + class QLabel; -class QTimer; class XGUI_OperationMgr; class XGUI_Workshop; +class QCheckBox; +class QStackedWidget; /// the plane edge width #define SKETCH_WIDTH "4" @@ -35,23 +39,32 @@ class XGUI_Workshop; * A model widget implementation for a label which provides specific behaviour * for sketcher starting and launching operations */ -class PARTSET_EXPORT PartSet_WidgetSketchLabel : public ModuleBase_ModelWidget +class PARTSET_EXPORT PartSet_WidgetSketchLabel : public ModuleBase_WidgetValidated { Q_OBJECT - public: + +public: /// Constructor /// \param theParent the parent object + /// \param theWorkshop a reference to 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_WidgetSketchLabel(QWidget* theParent, const Config_WidgetAPI* theData, - const std::string& theParentId); + /// \param toShowConstraints a current show constraints state + PartSet_WidgetSketchLabel(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop, + const Config_WidgetAPI* theData, + const std::string& theParentId, + const QMap& 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 + /// \param theToValidate a validation flag + virtual bool setSelection(QList& theValues, + const bool theToValidate); /// Returns list of widget controls /// \return a control list @@ -60,21 +73,39 @@ 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; + /// This control accepts focus + virtual bool focusTo(); + virtual void setHighlighted(bool) { /*do nothing*/ }; + virtual void enableFocusProcessing(); + signals: /// Signal on plane selection void planeSelected(const std::shared_ptr& thePln); + /// A show constraint toggled signal + /// \param theState a state of the check box + /// \param theType a ConstraintVisibleState value + void showConstraintToggled(bool theState, int theType); + protected: + /// Creates a backup of the current values of the attribute + /// It should be realized in the specific widget because of different + /// parameters of the current attribute + virtual void storeAttributeValue(); + + /// Creates a backup of the current values of the attribute + /// It should be realized in the specific widget because of different + /// parameters of the current attribute + /// \param theValid a boolean flag, if restore happens for valid parameters + virtual void restoreAttributeValue(const bool theValid); + + /// Fills the attribute with the value of the selected owner + /// \param thePrs a selected owner + virtual bool setSelectionCustom(const ModuleBase_ViewerPrs& thePrs); + /// Saves the internal parameters to the given feature /// \return True in success virtual bool storeValueCustom() const @@ -82,15 +113,43 @@ protected: return true; } + virtual bool restoreValueCustom() + { + return true; + } + /// The methiod called when widget is activated virtual void activateCustom(); + /// Block the model flush of update and intialization of attribute + /// In additional to curstom realization it blocks initialization for all feature attributes + /// as the current attribute is selection but its modification leads to other attributes change + /// \param theToBlock flag whether the model is blocked or unblocked + /// \param isActive out value if model is blocked, in value if model is unblocked + /// to be used to restore flush state when unblocked + /// \param isAttributeSetInitializedBlocked out value if model is blocked + /// in value if model is unblocked to be used to restore previous state when unblocked + virtual void blockAttribute(const bool& theToBlock, bool& isFlushesActived, + bool& isAttributeSetInitializedBlocked); + + /// 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 plane selection - void onPlaneSelected(); + /// Slot on change selection + void onSelectionChanged(); - /// Set sketch specific mode of selection - void setSketchingMode(); + /// A slot called on set sketch plane view + void onSetPlaneView(); + + /// Emits signal about check box state changed with information about ConstraintVisibleState + /// \param theOn a flag show constraints or not + void onShowConstraint(bool theOn); private: /// Create preview of planes for sketch plane selection @@ -101,6 +160,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); @@ -112,20 +174,16 @@ protected: void showPreviewPlanes(); - QLabel* myLabel; - QString myText; - QString myTooltip; - - XGUI_Workshop* myWorkshop; - AISObjectPtr myYZPlane; AISObjectPtr myXZPlane; AISObjectPtr myXYPlane; bool myPreviewDisplayed; - Handle(StdSelect_FaceFilter) myFaceFilter; + QCheckBox* myViewInverted; + + QMap myShowConstraints; - QTimer* mySelectionTimer; + QStackedWidget* myStackWidget; }; #endif