X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_WidgetSketchLabel.h;h=30efc49ec353e0f177d660dc41f78b4277d0f884;hb=fb54db5e1466b16dfc029c4a7364a67a9a6a8c24;hp=956b06ee0ec71a8ae29c5de77187b733808cba22;hpb=2a180ef10197cde8d43ae2d08cc9e1e40bdbc1e5;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetSketchLabel.h b/src/PartSet/PartSet_WidgetSketchLabel.h index 956b06ee0..30efc49ec 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,10 +73,10 @@ public: virtual void setHighlighted(bool) { /*do nothing*/ }; virtual void enableFocusProcessing(); - static bool canFillSketch(const ModuleBase_ViewerPrs& thePrs); + static bool canFillSketch(const std::shared_ptr& thePrs); static bool fillSketchPlaneBySelection(const FeaturePtr& theFeature, - const ModuleBase_ViewerPrs& thePrs); + const std::shared_ptr& thePrs); signals: /// Signal on plane selection @@ -97,17 +91,20 @@ 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 @@ -132,12 +129,22 @@ protected: /// 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 @@ -155,33 +162,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;