Salome HOME
Mirror for external objects.
[modules/shaper.git] / src / PartSet / PartSet_WidgetMultiSelector.h
1 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D
2
3 // File:        PartSet_WidgetMultiSelector.h
4 // Created:     15 Apr 2015
5 // Author:      Natalia Ermolaeva
6
7
8 #ifndef PartSet_WidgetMultiSelector_H
9 #define PartSet_WidgetMultiSelector_H
10
11 #include "PartSet.h"
12
13 #include <ModuleBase_WidgetMultiSelector.h>
14 #include <ModuleBase_ViewerPrs.h>
15
16 #include <ModelAPI_CompositeFeature.h>
17
18 class PartSet_ExternalObjectsMgr;
19
20 /**
21 * \ingroup Modules
22 * Customosation of ModuleBase_WidgetMultiSelector in order to provide 
23 * working with sketch specific objects and creation of external objects.
24 */
25 class PARTSET_EXPORT PartSet_WidgetMultiSelector: public ModuleBase_WidgetMultiSelector
26 {
27 Q_OBJECT
28  public:
29   /// Constructor
30   /// \param theParent the parent object
31   /// \param theWorkshop instance of workshop interface
32   /// \param theData the widget configuation. The attribute of the model widget is obtained from
33   /// \param theParentId is Id of a parent of the current attribute
34   PartSet_WidgetMultiSelector(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop,
35     const Config_WidgetAPI* theData, const std::string& theParentId);
36
37   virtual ~PartSet_WidgetMultiSelector();
38
39   /// Set sketcher
40   /// \param theSketch a sketcher object
41   void setSketcher(CompositeFeaturePtr theSketch) { mySketch = theSketch; }
42
43   /// Retrurns installed sketcher
44   CompositeFeaturePtr sketch() const { return mySketch; }
45
46   /// Fills the attribute with the value of the selected owner
47   /// \param theOwner a selected owner
48   virtual bool setSelectionCustom(const ModuleBase_ViewerPrs& thePrs);
49
50 protected:
51   /// Creates a backup of the current values of the attribute
52   /// It should be realized in the specific widget because of different
53   /// parameters of the current attribute
54   /// \param theValid a boolean flag, if restore happens for valid parameters
55   void restoreAttributeValue(const bool theValid);
56
57   /// Store the values to the model attribute of the widget. It casts this attribute to
58   /// the specific type and set the given values
59   /// \param theSelectedObject an object
60   /// \param theShape a selected shape, which is used in the selection attribute
61   /// \return true if it is succeed
62   bool setObject(const ObjectPtr& theSelectedObject, const GeomShapePtr& theShape);
63
64 protected:
65   PartSet_ExternalObjectsMgr* myExternalObjectMgr;
66   /// Pointer to a sketch 
67   CompositeFeaturePtr mySketch;
68 };
69
70 #endif