X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ViewerProxy.h;h=1e13f70cd589c06e7084fb7041c09160f5c8ea2b;hb=5544702339b340e6e612420ecbab44a033828d87;hp=dfd632bdab9699a1497f78fcdca15e941d36f6c7;hpb=50eee93b00efc7e0e2595937d9cba45e131ca8cb;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ViewerProxy.h b/src/XGUI/XGUI_ViewerProxy.h index dfd632bda..1e13f70cd 100644 --- a/src/XGUI/XGUI_ViewerProxy.h +++ b/src/XGUI/XGUI_ViewerProxy.h @@ -1,33 +1,50 @@ +// 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; +#include + +#ifndef HAVE_SALOME + #include +#endif +class XGUI_Workshop; /** -* 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 + * \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 + * functionality instead of direct access to a viewer + */ +class XGUI_EXPORT XGUI_ViewerProxy : public ModuleBase_IViewer { - Q_OBJECT -public: +Q_OBJECT + public: + /// Constructor + /// \param theParent a parent object XGUI_ViewerProxy(XGUI_Workshop* theParent); + /// Connects some signals to the viewer from the module connector + void connectViewProxy(); + //! Returns AIS_InteractiveContext from current OCCViewer virtual Handle(AIS_InteractiveContext) AISContext() const; + //! Trihedron 3d object shown in the viewer + virtual Handle(AIS_Trihedron) trihedron() const; + //! Retrurns V3d_Vioewer from current viewer virtual Handle(V3d_Viewer) v3dViewer() const; //! Returns Vsd_View object from currently active view window virtual Handle(V3d_View) activeView() const; + virtual QWidget* activeViewPort() const; + //! Enable or disable selection in the viewer virtual void enableSelection(bool isEnabled); @@ -40,27 +57,83 @@ public: //! Returns true if multiselection is enabled virtual bool isMultiSelectionEnabled() const; + //! Enable or disable draw mode in the viewer + virtual bool enableDrawMode(bool isEnabled); + //! Sets the view projection /// \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); + /// \param theTwist the twist angle in radians + virtual void setViewProjection( double theX, double theY, double theZ, + double theTwist ); //! Sets the view fitted all - void fitAll(); + 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); + + /// 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(); + + /// Signal emited on selection changed + void trihedronVisibilityChanged(bool theState); + +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 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 onViewCreated(ModuleBase_IViewWindow* theWnd); + +#ifndef HAVE_SALOME + 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*); + + void onViewTransformed(AppElements_ViewWindow::OperationType); +#endif + + private: XGUI_Workshop* myWorkshop; };