+ virtual void selectedShapes(NCollection_List<TopoDS_Shape>& theShapes,
+ std::list<ObjectPtr>& theOwners) const;
+
+ //! Returns list of currently selected owners
+ /// \return list of owners
+ void selectedOwners(SelectMgr_IndexedMapOfOwner& theSelectedOwners) const;
+
+ //! Returns a list of selection entity owners of the interactive object
+ /// It depends on the modes, in which the object is activated in the context
+ /// \param theObject an object
+ /// \param theOwners a map of entity owners
+ void entityOwners(const Handle_AIS_InteractiveObject& theObject,
+ SelectMgr_IndexedMapOfOwner& theOwners) const;
+
+ //! Return the IO from the viewer presentation.
+ //! \param thePrs a selected object
+ //! \return an interactive object
+ virtual Handle(AIS_InteractiveObject) getIO(const ModuleBase_ViewerPrs& thePrs);
+
+protected:
+ /// Fills the list of presentations by objects selected in the viewer.
+ /// \param thePresentations an output list of presentation
+ void getSelectedInViewer(QList<ModuleBase_ViewerPrs>& thePresentations) const;
+ /// Fills the list of presentations by objects selected in the object browser.
+ /// ViewerPrs contains only object parameter not empty.
+ /// If the given list of presentations already has a viewer presentation with the same object
+ /// as selected in the browser, a new item is not appended to the list of presentations.
+ /// \param thePresentations an output list of presentation
+ void getSelectedInBrowser(QList<ModuleBase_ViewerPrs>& thePresentations) const;
+
+ /// Generates a vertex or edge by the give IO if it is an AIS created on trihedron
+ /// \param theIO a selected object
+ /// \return created shape or empty shape
+ TopoDS_Shape findAxisShape(Handle(AIS_InteractiveObject) theIO) const;