X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_WidgetShapeSelector.h;h=93cf342d77248d5524a6dd0b9c6dfa401ef85a78;hb=33c5fdce3cd63dd95a738439a0399dd982abcd73;hp=c342e07014ccaf0f14ea7e9d45c7f3624e86258f;hpb=90c499710fd0db7a6b744457f5b7bac32096f4e1;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetShapeSelector.h b/src/PartSet/PartSet_WidgetShapeSelector.h index c342e0701..93cf342d7 100644 --- a/src/PartSet/PartSet_WidgetShapeSelector.h +++ b/src/PartSet/PartSet_WidgetShapeSelector.h @@ -14,11 +14,12 @@ #include +class PartSet_ExternalObjectsMgr; /** * \ingroup Modules * Customosation of ModuleBase_WidgetShapeSelector in order to provide -* working with sketch specific objects. +* working with sketch specific objects and external objects. */ class PARTSET_EXPORT PartSet_WidgetShapeSelector: public ModuleBase_WidgetShapeSelector { @@ -30,10 +31,9 @@ Q_OBJECT /// \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) - : ModuleBase_WidgetShapeSelector(theParent, theWorkshop, theData, theParentId) {} + const Config_WidgetAPI* theData, const std::string& theParentId); - virtual ~PartSet_WidgetShapeSelector() {} + virtual ~PartSet_WidgetShapeSelector(); /// Set sketcher /// \param theSketch a sketcher object @@ -42,17 +42,23 @@ Q_OBJECT /// Retrurns installed sketcher CompositeFeaturePtr sketch() const { return mySketch; } -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 storeAttributeValues(ObjectPtr theSelectedObject, GeomShapePtr theShape); + /// Activate or deactivate selection and selection filters + /// \param toActivate boolean state whether it should be activated/deactivated + virtual bool activateSelectionAndFilters(bool toActivate); - /// 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(); +protected: + /// 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 ModuleBase_ViewerPrs& 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 ModuleBase_ViewerPrs& 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 @@ -60,20 +66,14 @@ protected: /// \param theValid a boolean flag, if restore happens for valid parameters void restoreAttributeValue(const bool theValid); - // Removes the external presentation from the model - /// \param theSelectedObject an object - /// \param theShape a selected shape, which is used in the selection attribute - void createExternal(ObjectPtr theSelectedObject, GeomShapePtr theShape); - - // Removes the external presentation from the model - void removeExternal(); - protected: + /// A reference to external objects manager + PartSet_ExternalObjectsMgr* myExternalObjectMgr; + /// Pointer to a sketch CompositeFeaturePtr mySketch; - /// An external object - ObjectPtr myExternalObject; + bool myUseSketchPlane; /// state whether the sketch plane filter should be switched on }; #endif \ No newline at end of file