+// Copyright (C) 2014-20xx CEA/DEN, EDF R&D -->
+
#ifndef XGUI_SelectionMgr_H
#define XGUI_SelectionMgr_H
#include "XGUI.h"
#include <ModuleBase_Definitions.h>
+#include <ModuleBase_ISelection.h>
#include <QObject>
#include <QModelIndexList>
#include <AIS_ListOfInteractive.hxx>
#include <NCollection_List.hxx>
#include <TopoDS_Shape.hxx>
+#include <SelectMgr_IndexedMapOfOwner.hxx>
class XGUI_Workshop;
class XGUI_ObjectsBrowser;
*/
class XGUI_EXPORT XGUI_SelectionMgr : public QObject
{
- Q_OBJECT
-public:
+Q_OBJECT
+ public:
+ /// Constructor
+ /// \param theParent a parent workshop
XGUI_SelectionMgr(XGUI_Workshop* theParent);
virtual ~XGUI_SelectionMgr();
- XGUI_Selection* selection() const { return mySelection; }
+ /// Returns current selection
+ XGUI_Selection* selection() const
+ {
+ return mySelection;
+ }
- //! Returns list of currently selected data objects
- //QFeatureList selectedFeatures() const;
-
- //! Returns list of currently selected QModelIndexes
- //QModelIndexList selectedIndexes() const;
+ //! Connects the manager to all viewers accessible by Workshop
+ void connectViewers();
- //! Returns list of currently selected AIS objects
- //void selectedAISObjects(AIS_ListOfInteractive& theList) const;
+ //! Selects the owners in the context.
+ //! \param theSelectedOwners a container of owners
+ /// \param isUpdateViewer the parameter whether the viewer should be update immediatelly
+ void setSelectedOwners(const SelectMgr_IndexedMapOfOwner& theSelectedOwners,
+ bool isUpdateViewer);
- //! Returns list of currently selected shapes
- //void selectedShapes(NCollection_List<TopoDS_Shape>& theList) const;
+ //! Check that the selected owners are valid for the current filters
+ /// \param isUpdateViewer the parameter whether the viewer should be update immediatelly
+ void updateSelectedOwners(bool isUpdateViewer);
- //! Connects the manager to all viewers accessible by Workshop
- void connectViewers();
+ //! Clears selection in Viewer and object Browser
+ void clearSelection();
+
+ /// Updates selection, which are depend on the selection in the given place
+ /// \param thePlace a widget where selection has happened.
+ void updateSelectionBy(const ModuleBase_ISelection::SelectionPlace& thePlace);
signals:
//! Emited when selection in a one of viewers was changed
void selectionChanged();
-private slots:
+ private slots:
+ /// Reaction on selectio0n in Object browser
void onObjectBrowserSelection();
+
+ /// Reaction on selectio0n in Viewer
void onViewerSelection();
-private:
+ private:
+ /// Reference to workshop
XGUI_Workshop* myWorkshop;
+
+ /// Current selection object
XGUI_Selection* mySelection;
};