X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_WidgetMultiSelector.h;h=fa73d37590badcdc8f17d95f39031b73357c7837;hb=a2982d2108f929cf9e7f996cfd590c4ce59dc21c;hp=bf8f8841a021a813aaf3ed2af162f98639370ded;hpb=87a4570b2f2dd79c00d85b140c587f0e9e88a837;p=modules%2Fshaper.git
diff --git a/src/ModuleBase/ModuleBase_WidgetMultiSelector.h b/src/ModuleBase/ModuleBase_WidgetMultiSelector.h
index bf8f8841a..fa73d3759 100644
--- a/src/ModuleBase/ModuleBase_WidgetMultiSelector.h
+++ b/src/ModuleBase/ModuleBase_WidgetMultiSelector.h
@@ -31,10 +31,30 @@ class QComboBox;
class ModuleBase_IWorkshop;
class QAction;
+
+/**
+* \ingroup GUI
+* Implementation of widget for shapes selection. This widget provides selection of several shapes.
+* It can be defined in XML file as following:
+* \code
+*
+* \endcode
+* It uses folloing parameters:
+* - id - is a name of corresponded attribute
+* - tooltip - a tooltip for the widget
+* - type_choice - list of expected shape types.
+*/
class MODULEBASE_EXPORT ModuleBase_WidgetMultiSelector : public ModuleBase_ModelWidget
{
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
ModuleBase_WidgetMultiSelector(QWidget* theParent,
ModuleBase_IWorkshop* theWorkshop,
const Config_WidgetAPI* theData,
@@ -42,7 +62,6 @@ class MODULEBASE_EXPORT ModuleBase_WidgetMultiSelector : public ModuleBase_Model
virtual ~ModuleBase_WidgetMultiSelector();
/// Saves the internal parameters to the given feature
- /// \param theObject a model feature to be changed
virtual bool storeValue() const;
virtual bool restoreValue();
@@ -55,28 +74,49 @@ class MODULEBASE_EXPORT ModuleBase_WidgetMultiSelector : public ModuleBase_Model
/// \return a control list
virtual QList getControls() const;
- virtual bool eventFilter(QObject* theObj, QEvent* theEvent);
+ virtual bool eventFilter(QObject* , QEvent* );
public slots:
+ /// Activate or deactivate selection
void activateSelection(bool toActivate);
+
+ /// Slot is called on selection type changed
void onSelectionTypeChanged();
+
+ /// Slot is called on selection changed
void onSelectionChanged();
protected slots:
+ /// Slot for copy command in a list pop-up menu
void onCopyItem();
+
+ /// Slot is called on selection of list of selected items
void onListSelection();
protected:
+ /// Provide filtering of selected shapes
+ /// \param theShapesToFilter source list of shapes
+ /// \param theResult result list of shapes
void filterShapes(const NCollection_List& theShapesToFilter,
NCollection_List& theResult);
+
+ /// Set current shape type for selection
void setCurrentShapeType(const TopAbs_ShapeEnum theShapeType);
+
+ /// Start shape selection
void activateShapeSelection();
private:
+ /// Update selection list
void updateSelectionList(AttributeSelectionListPtr);
+ /// List control
QListWidget* myListControl;
+
+ /// Combobox of types
QComboBox* myTypeCombo;
+
+ /// Container
QWidget* myMainWidget;
//TODO: Move into the base of selectors
@@ -85,9 +125,13 @@ protected slots:
/// If true then local selector has to be activated in context
bool myIsActive;
+ /// Provides correspondance between Result object and its shape
typedef QPair GeomSelection;
+
+ /// Variable of GeomSelection type
QList mySelection;
+ /// An action for pop-up menu in a list control
QAction* myCopyAction;
};