X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_WidgetSketchLabel.h;h=30efc49ec353e0f177d660dc41f78b4277d0f884;hb=fb54db5e1466b16dfc029c4a7364a67a9a6a8c24;hp=709c57efa0f7ce68d0c78c5215b7bd855d3ec6d6;hpb=2a13d12cee28a6c60b2db50dc63529a65e1f3b1e;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetSketchLabel.h b/src/PartSet/PartSet_WidgetSketchLabel.h index 709c57efa..30efc49ec 100644 --- a/src/PartSet/PartSet_WidgetSketchLabel.h +++ b/src/PartSet/PartSet_WidgetSketchLabel.h @@ -9,27 +9,25 @@ #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; class QStackedWidget; -/// 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 @@ -38,16 +36,16 @@ class QStackedWidget; 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 /// \param toShowConstraints a current show constraints state PartSet_WidgetSketchLabel(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop, - const Config_WidgetAPI* theData, - const std::string& theParentId, bool toShowConstraints); + const Config_WidgetAPI* theData, + const QMap& toShowConstraints); virtual ~PartSet_WidgetSketchLabel(); @@ -57,7 +55,7 @@ Q_OBJECT /// 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, + virtual bool setSelection(QList>& theValues, const bool theToValidate); /// Returns list of widget controls @@ -75,32 +73,38 @@ Q_OBJECT virtual void setHighlighted(bool) { /*do nothing*/ }; virtual void enableFocusProcessing(); - /// Set show constraints state - /// \param theOn a flag show constraints or not - 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); /// A show constraint toggled signal - void showConstraintToggled(bool); + /// \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 thePrs a selected owner - virtual bool setSelectionCustom(const ModuleBase_ViewerPrs& thePrs); + virtual bool setSelectionCustom(const std::shared_ptr& thePrs); /// Saves the internal parameters to the given feature /// \return True in success @@ -117,9 +121,30 @@ protected: /// 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 ModuleBase_ViewerPrs& thePrs); + void updateByPlaneSelected(const std::shared_ptr& thePrs); protected: /// Activate or deactivate selection @@ -132,37 +157,25 @@ protected: /// A slot called on set sketch plane view void onSetPlaneView(); - 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]); - - //! Returns workshop - XGUI_Workshop* workshop() const; + /// 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); + static std::shared_ptr setSketchPlane(const FeaturePtr& theFeature, + const TopoDS_Shape& theShape); - /// Erase preview planes - void erasePreviewPlanes(); - /// Show preview planes - void showPreviewPlanes(); +private: + /// class to show/hide preview planes + PartSet_PreviewPlanes* myPreviewPlanes; - - AISObjectPtr myYZPlane; - AISObjectPtr myXZPlane; - AISObjectPtr myXYPlane; - bool myPreviewDisplayed; - - QCheckBox* myShowConstraints; QCheckBox* myViewInverted; + QMap myShowConstraints; + QStackedWidget* myStackWidget; };