X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_WidgetSketchLabel.h;h=30efc49ec353e0f177d660dc41f78b4277d0f884;hb=def1d660542e39cc9ed4ee27ab8cce8d231be01a;hp=0dc7c07f63f547d1dff933fd3f504213724d240e;hpb=179d6f9656ac229aa724f98742bf3e0f07f23e0f;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetSketchLabel.h b/src/PartSet/PartSet_WidgetSketchLabel.h index 0dc7c07f6..30efc49ec 100644 --- a/src/PartSet/PartSet_WidgetSketchLabel.h +++ b/src/PartSet/PartSet_WidgetSketchLabel.h @@ -9,25 +9,24 @@ #include "PartSet.h" +#include "PartSet_Tools.h" + #include #include -#include #include -#include #include +#include + +class PartSet_PreviewPlanes; + class QLabel; 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" +class QStackedWidget; /** * \ingroup Modules @@ -37,13 +36,16 @@ class QCheckBox; 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, bool toShowConstraints); + /// \param toShowConstraints a current show constraints state + PartSet_WidgetSketchLabel(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop, + const Config_WidgetAPI* theData, + const QMap& toShowConstraints); virtual ~PartSet_WidgetSketchLabel(); @@ -52,13 +54,9 @@ Q_OBJECT /// 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 thePosition an index in the list of values, the values should be get from the index - virtual bool setSelection(const QList& theValues, int& thePosition); - - virtual bool restoreValue() - { - return true; - } + /// \param theToValidate a validation flag + virtual bool setSelection(QList>& theValues, + const bool theToValidate); /// Returns list of widget controls /// \return a control list @@ -67,13 +65,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; @@ -82,29 +73,38 @@ Q_OBJECT virtual void setHighlighted(bool) { /*do nothing*/ }; virtual void enableFocusProcessing(); - void showConstraints(bool theOn); + static bool canFillSketch(const std::shared_ptr& thePrs); + + static bool fillSketchPlaneBySelection(const FeaturePtr& theFeature, + const std::shared_ptr& thePrs); signals: /// Signal on plane selection void planeSelected(const std::shared_ptr& thePln); - void showConstraintToggled(bool); + /// A show constraint toggled signal + /// \param theType a ConstraintVisibleState value + /// \param theState a state of the check box + void showConstraintToggled(int theType, bool theState); 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(); + /// \param theAttribute an attribute to be stored + virtual void storeAttributeValue(const AttributePtr& theAttribute); /// 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 theAttribute an attribute to be restored /// \param theValid a boolean flag, if restore happens for valid parameters - virtual void restoreAttributeValue(const bool theValid); + virtual void restoreAttributeValue(const AttributePtr& theAttribute, + 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); + /// \param thePrs a selected owner + virtual bool setSelectionCustom(const std::shared_ptr& thePrs); /// Saves the internal parameters to the given feature /// \return True in success @@ -113,9 +113,39 @@ 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 AttributePtr& theAttribute, const bool& theToBlock, + bool& isFlushesActived, + bool& isAttributeSetInitializedBlocked); + + /// 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 + bool setSelectionInternal(const QList>& theValues, + const bool theToValidate); + + /// Erase preview planes, disconnect widget, change the view projection + /// \param thePrs a selected presentation + void updateByPlaneSelected(const std::shared_ptr& thePrs); + protected: /// Activate or deactivate selection void activateSelection(bool toActivate); @@ -124,38 +154,29 @@ protected: /// Slot on change selection void onSelectionChanged(); - private: - /// Create preview of planes for sketch plane selection - /// \param theOrigin an origin of the plane - /// \param theNorm a normal vector of the plane - /// \param theRGB a color of plane presentation [r, g, b] array - AISObjectPtr createPreviewPlane(std::shared_ptr theOrigin, - std::shared_ptr theNorm, - const int theRGB[3]); + /// 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: /// Set sketch plane by shape /// \param theShape a planar face - std::shared_ptr setSketchPlane(const TopoDS_Shape& theShape); - - /// Erase preview planes - void erasePreviewPlanes(); - - /// Show preview planes - void showPreviewPlanes(); + static std::shared_ptr setSketchPlane(const FeaturePtr& theFeature, + const TopoDS_Shape& theShape); - QLabel* myLabel; - QString myText; - QString myTooltip; +private: + /// class to show/hide preview planes + PartSet_PreviewPlanes* myPreviewPlanes; - XGUI_Workshop* myWorkshop; + QCheckBox* myViewInverted; - AISObjectPtr myYZPlane; - AISObjectPtr myXZPlane; - AISObjectPtr myXYPlane; - bool myPreviewDisplayed; + QMap myShowConstraints; - QCheckBox* myShowConstraints; + QStackedWidget* myStackWidget; }; #endif