Salome HOME
Corrections for extrusion/revolution xml definition and random color
[modules/shaper.git] / src / XGUI / XGUI_SelectionMgr.h
index 58af58ea0515878ba974481329f58e539ec0a8f4..a38546fa0d88a36ff03d6f9b75cf0715abab1b2e 100644 (file)
@@ -1,38 +1,75 @@
+// Copyright (C) 2014-20xx CEA/DEN, EDF R&D -->
+
 #ifndef XGUI_SelectionMgr_H
 #define XGUI_SelectionMgr_H
 
-#include "XGUI_Constants.h"
+#include "XGUI.h"
+#include <ModuleBase_Definitions.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_Selection;
 
 /**\class XGUI_SelectionMgr
  * \ingroup GUI
  * \brief Selection manager. Provides selection event on selection in 
  * Object Browser and Viewer
  */
-class XGUI_SelectionMgr : public QObject
+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();
 
-  //! Returns list of currently selected objects
-  QFeatureList selectedData() const { return mySelectedData; }
+  /// Returns current selection
+  XGUI_Selection* selection() const
+  {
+    return mySelection;
+  }
+
+  //! Connects the manager to all viewers accessible by Workshop
+  void connectViewers();
+
+  //! 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);
+
+  //! 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);
+
+  //! Clears selection in Viewer and object Browser
+  void clearSelection();
 
 signals:
   //! Emited when selection in a one of viewers was changed
   void selectionChanged();
 
-public slots:
-  void onSelectionChanged();
+ 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;
 
-  //! List of selected features
-  QFeatureList mySelectedData;
+  /// Current selection object
+  XGUI_Selection* mySelection;
 };
 
-#endif;
\ No newline at end of file
+#endif