X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_WidgetSketchLabel.h;h=ab7cd18eb35737396accc48f7e5b4be2a0cb4471;hb=6f31859c9897eacec13d3912e76f28b8b824ecf4;hp=9c9ffad2cc8a4007c626792c5d06b205821b9e44;hpb=e5b2e13f8b3609856b888ad53c3cdcbb9f47cf6b;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetSketchLabel.h b/src/PartSet/PartSet_WidgetSketchLabel.h index 9c9ffad2c..ab7cd18eb 100644 --- a/src/PartSet/PartSet_WidgetSketchLabel.h +++ b/src/PartSet/PartSet_WidgetSketchLabel.h @@ -9,27 +9,33 @@ #include "PartSet.h" -#include +#include #include #include #include #include -#include #include class QLabel; -class QTimer; +//class QTimer; class XGUI_OperationMgr; class XGUI_Workshop; +class QCheckBox; + +/// the plane edge width +#define SKETCH_WIDTH "4" + +/// face of the square-face displayed for selection of general plane +#define PLANE_SIZE "200" /** * \ingroup Modules * 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: @@ -38,15 +44,10 @@ Q_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, - const std::string& theParentId); + const std::string& theParentId, bool toShowConstraints); virtual ~PartSet_WidgetSketchLabel(); - virtual bool storeValue() const - { - return true; - } - virtual bool restoreValue() { return true; @@ -56,8 +57,6 @@ Q_OBJECT /// \return a control list virtual QList getControls() const; - QWidget* getControl() const; - /// The methiod called when widget is deactivated virtual void deactivate(); @@ -71,20 +70,51 @@ Q_OBJECT /// Returns sketcher plane std::shared_ptr plane() const; + /// This control accepts focus + virtual bool focusTo(); + virtual void setHighlighted(bool) { /*do nothing*/ }; + virtual void enableFocusProcessing(); + + void showConstraints(bool theOn); + signals: /// Signal on plane selection void planeSelected(const std::shared_ptr& thePln); + void showConstraintToggled(bool); + 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 theOwner 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 + { + return true; + } + /// The methiod called when widget is activated virtual void activateCustom(); private slots: - /// Slot on plane selection - void onPlaneSelected(); + /// Slot on change selection + void onSelectionChanged(); /// Set sketch specific mode of selection - void setSketchingMode(); + //void setSketchingMode(); private: /// Create preview of planes for sketch plane selection @@ -117,9 +147,9 @@ protected: AISObjectPtr myXYPlane; bool myPreviewDisplayed; - Handle(StdSelect_FaceFilter) myFaceFilter; + //QTimer* mySelectionTimer; - QTimer* mySelectionTimer; + QCheckBox* myShowConstraints; }; #endif