+ /// Add selection filter to the viewer
+ virtual void addSelectionFilter(const Handle(SelectMgr_Filter)& theFilter);
+
+ /// Remove selection filter from the viewer
+ virtual void removeSelectionFilter(const Handle(SelectMgr_Filter)& theFilter);
+
+ /// Returns true if the selection filter is set to the viewer
+ /// \param theFilter a selection filter
+ virtual bool hasSelectionFilter(const Handle(SelectMgr_Filter)& theFilter);
+
+ /// Remove all selection filters from the viewer
+ virtual void clearSelectionFilters();
+
+ /// Update current viewer
+ virtual void update();
+
+ /// Method returns True if the viewer can process editing objects
+ /// by mouse drugging. If this is impossible thet it has to return False.
+ virtual bool canDragByMouse() const;
+
+ // Fit all along Z (perpendicular to display)
+ virtual void Zfitall();
+
+signals:
+ /// Emits by mouse entering the view port
+ void enterViewPort();
+
+ /// Emits by mouse leaving of the view port
+ void leaveViewPort();
+
+protected:
+ /// processes the application signals to catch the mouse leaving state of the main window
+ /// \param theObject
+ /// \param theEvent
+ bool eventFilter(QObject *theObject, QEvent *theEvent);
+