X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;ds=inline;f=src%2FPartSet%2FPartSet_WidgetSketchLabel.h;h=526207a8a3dd1a6574b1063569422991e617296e;hb=c8ab29e531ee03054976a7606076f2c4ee1d9f6b;hp=ff6689d1cb74bc333cb99596c50cdf544cb3581f;hpb=ee32391a69cf3aa5bc7d0a4d6ec53150f1f4a467;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetSketchLabel.h b/src/PartSet/PartSet_WidgetSketchLabel.h index ff6689d1c..526207a8a 100644 --- a/src/PartSet/PartSet_WidgetSketchLabel.h +++ b/src/PartSet/PartSet_WidgetSketchLabel.h @@ -14,26 +14,20 @@ #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 @@ -61,7 +55,7 @@ public: /// 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 @@ -79,8 +73,15 @@ public: virtual void setHighlighted(bool) { /*do nothing*/ }; virtual void enableFocusProcessing(); + /// Returns True if the selected presentation can be used for plane definition + /// \param thePrs a presentation + static bool canFillSketch(const std::shared_ptr& thePrs); + + /// Set sketch plane from selected object + /// \param theFeature a feature of sketch + /// \param thePrs a presentation static bool fillSketchPlaneBySelection(const FeaturePtr& theFeature, - const ModuleBase_ViewerPrs& thePrs); + const std::shared_ptr& thePrs); signals: /// Signal on plane selection @@ -95,21 +96,24 @@ 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 - virtual bool storeValueCustom() const + virtual bool storeValueCustom() { return true; } @@ -125,17 +129,28 @@ protected: /// 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 theAttribute an attribute /// \param theToBlock flag whether the model is blocked or unblocked - /// \param isActive out value if model is blocked, in value if model is unblocked + /// \param isFlushesActived 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, + 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 @@ -153,33 +168,15 @@ protected: void onShowConstraint(bool theOn); 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; - /// Set sketch plane by shape /// \param theShape a planar face static std::shared_ptr setSketchPlane(const FeaturePtr& theFeature, const TopoDS_Shape& theShape); - /// Erase preview planes - void erasePreviewPlanes(); - - /// Show preview planes - void showPreviewPlanes(); - - AISObjectPtr myYZPlane; - AISObjectPtr myXZPlane; - AISObjectPtr myXYPlane; - bool myPreviewDisplayed; +private: + /// class to show/hide preview planes + PartSet_PreviewPlanes* myPreviewPlanes; QCheckBox* myViewInverted;