X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_WidgetShapeSelector.h;h=9f8c44da659c2da5c32ae7960639d612eea5936b;hb=fb54db5e1466b16dfc029c4a7364a67a9a6a8c24;hp=050b64e271b479860c10a54c7952c24125d1482d;hpb=3574a5a3c5d5fd1105c92db5f5975ab2240344ce;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetShapeSelector.h b/src/PartSet/PartSet_WidgetShapeSelector.h index 050b64e27..9f8c44da6 100644 --- a/src/PartSet/PartSet_WidgetShapeSelector.h +++ b/src/PartSet/PartSet_WidgetShapeSelector.h @@ -29,9 +29,8 @@ Q_OBJECT /// \param theParent the parent object /// \param theWorkshop instance of workshop interface /// \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_WidgetShapeSelector(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop, - const Config_WidgetAPI* theData, const std::string& theParentId); + const Config_WidgetAPI* theData); virtual ~PartSet_WidgetShapeSelector(); @@ -42,36 +41,38 @@ Q_OBJECT /// Retrurns installed sketcher CompositeFeaturePtr sketch() const { return mySketch; } + /// Activate or deactivate selection and selection filters + /// \param toActivate boolean state whether it should be activated/deactivated + virtual bool activateSelectionAndFilters(bool toActivate); + protected: - /// Store the values to the model attribute of the widget. It casts this attribute to - /// the specific type and set the given values - /// \param theSelectedObject an object - /// \param theShape a selected shape, which is used in the selection attribute - virtual bool setObject(ObjectPtr theSelectedObject, GeomShapePtr theShape); - - /// Get the shape from the attribute if the attribute contain a shape - /// It processes the ref attr type of attributes. It obtains the referenced attribute, - /// results of the attribute feature. And it founds a vertes in the owners of the results - /// If the vertex is found, it creates a geom shape on it. - /// \return a shape - virtual GeomShapePtr getShape() const; + /// Checks the widget validity. By default, it returns true. + /// \param thePrs a selected presentation in the view + /// \return a boolean value + virtual bool isValidSelectionCustom(const std::shared_ptr& thePrs); + + /// Return an object and geom shape by the viewer presentation + /// \param thePrs a selection + /// \param theObject an output object + /// \param theShape a shape of the selection + virtual void getGeomSelection(const std::shared_ptr& thePrs, + ObjectPtr& theObject, + GeomShapePtr& theShape); /// 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 - void restoreAttributeValue(const bool theValid); - - /// Found the sketch point attribute by the shape and set it in the feature attribute - /// otherwise set the selected object - /// \param theSelectedObject an object - /// \param theShape a selected shape, which is used in the selection attribute - void setPointAttribute(ObjectPtr theSelectedObject, GeomShapePtr theShape); + void restoreAttributeValue(const AttributePtr& theAttribute, const bool theValid); protected: + /// A reference to external objects manager PartSet_ExternalObjectsMgr* myExternalObjectMgr; + /// Pointer to a sketch CompositeFeaturePtr mySketch; + + bool myUseSketchPlane; /// state whether the sketch plane filter should be switched on }; #endif \ No newline at end of file