X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ViewerProxy.h;h=64bc12fb81a05fc59fb6bf4215a0f373adface70;hb=3975324fb3e40fc0c18eac0de7f50251d2eac9f8;hp=1f20b281b41cd01a5e55e0b02c8e595cf8e16dcc;hpb=f1cd93fd02a54259f72e3191d037323a496b2bef;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ViewerProxy.h b/src/XGUI/XGUI_ViewerProxy.h index 1f20b281b..64bc12fb8 100644 --- a/src/XGUI/XGUI_ViewerProxy.h +++ b/src/XGUI/XGUI_ViewerProxy.h @@ -5,11 +5,11 @@ #include "XGUI.h" #include +#include class XGUI_Workshop; -class AppElements_ViewWindow; - /** + * \ingroup GUI * Proxy class which repersents or AppElements_Viewer or Salome Viewer * dependently on current launching environment. * It is reccomennded to use this class in operation for accessing to viewer @@ -19,6 +19,8 @@ class XGUI_EXPORT XGUI_ViewerProxy : public ModuleBase_IViewer { Q_OBJECT public: + /// Constructor + /// \param theParent a parent object XGUI_ViewerProxy(XGUI_Workshop* theParent); //! Returns AIS_InteractiveContext from current OCCViewer @@ -46,7 +48,9 @@ Q_OBJECT /// \param theX the X projection value /// \param theY the Y projection value /// \param theZ the Z projection value - virtual void setViewProjection(double theX, double theY, double theZ); + /// \param theTwist the twist angle in radians + virtual void setViewProjection( double theX, double theY, double theZ, + double theTwist ); //! Sets the view fitted all virtual void fitAll(); @@ -60,12 +64,40 @@ Q_OBJECT /// 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); + private slots: void onTryCloseView(AppElements_ViewWindow*); void onDeleteView(AppElements_ViewWindow*); + void onViewCreated(ModuleBase_IViewWindow* theWnd); void onViewCreated(AppElements_ViewWindow*); void onActivated(AppElements_ViewWindow*); @@ -77,6 +109,8 @@ private slots: void onKeyPress(AppElements_ViewWindow*, QKeyEvent*); void onKeyRelease(AppElements_ViewWindow*, QKeyEvent*); + void onViewTransformed(AppElements_ViewWindow::OperationType); + private: XGUI_Workshop* myWorkshop; };