Salome HOME
Update from BR_V5_DEV 13Feb2009
[modules/gui.git] / src / LightApp / LightApp_SwitchOp.h
1 //  Copyright (C) 2007-2008  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 //  Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 //  CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
6 //  This library is free software; you can redistribute it and/or
7 //  modify it under the terms of the GNU Lesser General Public
8 //  License as published by the Free Software Foundation; either
9 //  version 2.1 of the License.
10 //
11 //  This library is distributed in the hope that it will be useful,
12 //  but WITHOUT ANY WARRANTY; without even the implied warranty of
13 //  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 //  Lesser General Public License for more details.
15 //
16 //  You should have received a copy of the GNU Lesser General Public
17 //  License along with this library; if not, write to the Free Software
18 //  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
19 //
20 //  See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22 #ifndef LightApp_SwitchOp_H
23 #define LightApp_SwitchOp_H
24
25 #include "LightApp.h"
26 #include <QObject>
27
28 class LightApp_Module;
29 class LightApp_Operation;
30 class QEvent;
31 class SUIT_Study;
32
33 /*!
34  * \brief This class is intended for controling switching between operation
35  *
36  * Several operation may be launched simultaneously. This class is intended for
37  * controlling switching between such operations. This class works with operations having
38  * dialogs (activation of other operations is performed by SUIT_Study). When several
39  * operations is launched simultaneously corresponding dialogs are shown on the screen.
40  * Only one operation from the launched ones can be active (active operation). Other
41  * operations are suspended. As result only one dialog from shown ones can be active too.
42  * Other dialogs are disabled. This class installs event filter on application. When mouse
43  * cursor is moved above disabled dialog corresponding event is catched by this class.
44  * It finds corresponding operation and verify whether operation can be resumed (see
45  * SUIT_Study::isDenied( SUIT_Operation* ) method). If yes then current active
46  * operation is suspended and new operation activated. Module contains this class as a
47  * field. Then module is created instance of this class created too.
48  */
49 class LIGHTAPP_EXPORT LightApp_SwitchOp : public QObject
50 {
51   Q_OBJECT
52
53 public:
54
55   LightApp_SwitchOp( LightApp_Module* );
56   virtual ~LightApp_SwitchOp();
57
58   // Redefined from base class
59   bool                     eventFilter( QObject*, QEvent* );
60
61 private:
62
63   LightApp_Module*         module() const;
64   LightApp_Operation*      operation( QWidget* ) const;
65   SUIT_Study*              study() const;
66   
67 private:
68   
69   LightApp_Module*         myModule;  
70
71 };
72
73 #endif
74
75
76
77
78
79