X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_SelectionMgr.h;h=a38546fa0d88a36ff03d6f9b75cf0715abab1b2e;hb=1be01557bbce2ce45f8f7e1cfce412005aa8e349;hp=e98b52841fb76fb321e910d51a52e1ebdbfb7b76;hpb=12621bb509825d0eb1fb0847a7f9c8011021ca5a;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_SelectionMgr.h b/src/XGUI/XGUI_SelectionMgr.h index e98b52841..a38546fa0 100644 --- a/src/XGUI/XGUI_SelectionMgr.h +++ b/src/XGUI/XGUI_SelectionMgr.h @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D --> + #ifndef XGUI_SelectionMgr_H #define XGUI_SelectionMgr_H @@ -9,9 +11,11 @@ #include #include #include +#include class XGUI_Workshop; class XGUI_ObjectsBrowser; +class XGUI_Selection; /**\class XGUI_SelectionMgr * \ingroup GUI @@ -20,37 +24,52 @@ 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(); - //! Returns list of currently selected data objects - QFeatureList selectedFeatures() const; - - //! Returns list of currently selected QModelIndexes - QModelIndexList selectedIndexes() const; - - //! Returns list of currently selected AIS objects - void selectedAISObjects(AIS_ListOfInteractive& theList) const; - - //! Returns list of currently selected shapes - void selectedShapes(NCollection_List& theList) const; + /// 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(); -private slots: + private slots: + /// Reaction on selectio0n in Object browser void onObjectBrowserSelection(); - void onViewerSelection(); -private: + /// Reaction on selectio0n in Viewer + void onViewerSelection(); + private: + /// Reference to workshop XGUI_Workshop* myWorkshop; + + /// Current selection object + XGUI_Selection* mySelection; }; #endif