X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_WidgetShapeSelector.h;h=a2ba2d2bd5310a1033f25f3cb53f2ab9a1966387;hb=6e73ccbe5ba45c2f6c1c7513ea20b502b245e2c8;hp=d4cf72aff480fa7674bf953a116297c9760bdf41;hpb=f1cd93fd02a54259f72e3191d037323a496b2bef;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetShapeSelector.h b/src/PartSet/PartSet_WidgetShapeSelector.h index d4cf72aff..a2ba2d2bd 100644 --- a/src/PartSet/PartSet_WidgetShapeSelector.h +++ b/src/PartSet/PartSet_WidgetShapeSelector.h @@ -14,44 +14,77 @@ #include +class PartSet_ExternalObjectsMgr; + +/** +* \ingroup Modules +* Customosation of ModuleBase_WidgetShapeSelector in order to provide +* working with sketch specific objects and external objects. +*/ class PARTSET_EXPORT PartSet_WidgetShapeSelector: public ModuleBase_WidgetShapeSelector { Q_OBJECT public: + /// Constructor + /// \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) - : ModuleBase_WidgetShapeSelector(theParent, theWorkshop, theData, theParentId) {} - - virtual ~PartSet_WidgetShapeSelector() {} + const Config_WidgetAPI* theData, const std::string& theParentId); - /// Saves the internal parameters to the given feature - virtual bool storeValue() const; + virtual ~PartSet_WidgetShapeSelector(); + /// Set sketcher + /// \param theSketch a sketcher object void setSketcher(CompositeFeaturePtr theSketch) { mySketch = theSketch; } - CompositeFeaturePtr sketch() const { return mySketch; } - -private: - CompositeFeaturePtr mySketch; -}; - -class PARTSET_EXPORT PartSet_WidgetConstraintShapeSelector: public ModuleBase_WidgetShapeSelector -{ -Q_OBJECT - public: - PartSet_WidgetConstraintShapeSelector(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop, - const Config_WidgetAPI* theData, const std::string& theParentId) - : ModuleBase_WidgetShapeSelector(theParent, theWorkshop, theData, theParentId) {} - - virtual ~PartSet_WidgetConstraintShapeSelector() {} - - /// Saves the internal parameters to the given feature - virtual bool storeValue() const; - - void setSketcher(CompositeFeaturePtr theSketch) { mySketch = theSketch; } + /// Retrurns installed sketcher CompositeFeaturePtr sketch() const { return mySketch; } -private: +protected: + /// Checks the widget validity. By default, it returns true. + /// \param theValue a selected presentation in the view + /// \return a boolean value + virtual bool isValidSelectionCustom(const ModuleBase_ViewerPrs& thePrs); + + /// 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 + /// \return true if it is succeed + virtual void setObject(ObjectPtr theSelectedObject, GeomShapePtr theShape); + + /// 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); + + /// 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; + + /// 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); + +protected: + PartSet_ExternalObjectsMgr* myExternalObjectMgr; + /// Pointer to a sketch CompositeFeaturePtr mySketch; };