X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ViewerProxy.h;h=bce1db650127e232a9a7c1a272add53edfbcbc76;hb=59a007784d1e103bcb352c515eb6feafa170f1ff;hp=acd152d23685994672d71022f89b639febba10ce;hpb=83bb88d84077d060259edddf8b789d88685800a6;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ViewerProxy.h b/src/XGUI/XGUI_ViewerProxy.h index acd152d23..bce1db650 100644 --- a/src/XGUI/XGUI_ViewerProxy.h +++ b/src/XGUI/XGUI_ViewerProxy.h @@ -6,9 +6,11 @@ #include "XGUI.h" #include -class XGUI_Workshop; -class AppElements_ViewWindow; +#ifndef HAVE_SALOME + #include +#endif +class XGUI_Workshop; /** * \ingroup GUI * Proxy class which repersents or AppElements_Viewer or Salome Viewer @@ -33,6 +35,8 @@ Q_OBJECT //! 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); @@ -45,11 +49,16 @@ Q_OBJECT //! 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 - 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(); @@ -63,6 +72,10 @@ 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(); @@ -73,7 +86,26 @@ Q_OBJECT /// 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 onViewCreated(ModuleBase_IViewWindow* theWnd); + +#ifndef HAVE_SALOME void onTryCloseView(AppElements_ViewWindow*); void onDeleteView(AppElements_ViewWindow*); void onViewCreated(AppElements_ViewWindow*); @@ -87,6 +119,9 @@ private slots: void onKeyPress(AppElements_ViewWindow*, QKeyEvent*); void onKeyRelease(AppElements_ViewWindow*, QKeyEvent*); + void onViewTransformed(AppElements_ViewWindow::OperationType); +#endif + private: XGUI_Workshop* myWorkshop; };