X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ViewerProxy.h;h=7cd1f90d6e7b8e3bb9bb439d1962a33ef6b446de;hb=be7d83df0061448606f62fcb370f59e2617557d1;hp=2d2864dd4f9a7cafd85d8687f25eca655852a23c;hpb=ff4aad301cd1f42683573988f65334f0db074655;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ViewerProxy.h b/src/XGUI/XGUI_ViewerProxy.h index 2d2864dd4..7cd1f90d6 100644 --- a/src/XGUI/XGUI_ViewerProxy.h +++ b/src/XGUI/XGUI_ViewerProxy.h @@ -1,22 +1,24 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D --> + #ifndef XGUI_VIEWERPROXY_H #define XGUI_VIEWERPROXY_H #include "XGUI.h" -#include "XGUI_SalomeViewer.h" +#include class XGUI_Workshop; -class XGUI_ViewWindow; +class AppElements_ViewWindow; /** -* Proxy class which repersents or XGUI_Viewer or Salome Viewer -* dependently on current launching environment. -* It is reccomennded to use this class in operation for accessing to viewer -* functionality instead of direct access to a viewer -*/ -class XGUI_EXPORT XGUI_ViewerProxy: public XGUI_SalomeViewer + * 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 + * functionality instead of direct access to a viewer + */ +class XGUI_EXPORT XGUI_ViewerProxy : public ModuleBase_IViewer { - Q_OBJECT -public: +Q_OBJECT + public: XGUI_ViewerProxy(XGUI_Workshop* theParent); //! Returns AIS_InteractiveContext from current OCCViewer @@ -44,21 +46,42 @@ public: /// \param theX the X projection value /// \param theY the Y projection value /// \param theZ the Z projection value - void setViewProjection(double theX, double theY, double theZ); + virtual void setViewProjection(double theX, double theY, double theZ); + + //! Sets the view fitted all + virtual void fitAll(); /// Connects to a viewer according to current environment void connectToViewer(); + /// 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); + + /// Remove all selection filters from the viewer + virtual void clearSelectionFilters(); + + /// Update current viewer + virtual void update(); + private slots: - void onMousePress(XGUI_ViewWindow*, QMouseEvent*); - void onMouseRelease(XGUI_ViewWindow*, QMouseEvent*); - void onMouseDoubleClick(XGUI_ViewWindow*, QMouseEvent*); - void onMouseMove(XGUI_ViewWindow*, QMouseEvent*); - void onKeyPress(XGUI_ViewWindow*, QKeyEvent*); - void onKeyRelease(XGUI_ViewWindow*, QKeyEvent*); - -private: + void onTryCloseView(AppElements_ViewWindow*); + void onDeleteView(AppElements_ViewWindow*); + void onViewCreated(AppElements_ViewWindow*); + void onActivated(AppElements_ViewWindow*); + + void onMousePress(AppElements_ViewWindow*, QMouseEvent*); + void onMouseRelease(AppElements_ViewWindow*, QMouseEvent*); + void onMouseDoubleClick(AppElements_ViewWindow*, QMouseEvent*); + void onMouseMove(AppElements_ViewWindow*, QMouseEvent*); + + void onKeyPress(AppElements_ViewWindow*, QKeyEvent*); + void onKeyRelease(AppElements_ViewWindow*, QKeyEvent*); + + private: XGUI_Workshop* myWorkshop; }; -#endif \ No newline at end of file +#endif