summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--library/qpemenubar.cpp16
-rw-r--r--library/qpemenubar.h2
2 files changed, 18 insertions, 0 deletions
diff --git a/library/qpemenubar.cpp b/library/qpemenubar.cpp
index 39f8fd6..bb3ad8d 100644
--- a/library/qpemenubar.cpp
+++ b/library/qpemenubar.cpp
@@ -181,128 +181,144 @@ bool QPEMenuToolFocusManager::eventFilter( QObject *object, QEvent *event )
181 QTimer::singleShot( 0, this, SLOT(deactivate()) ); 181 QTimer::singleShot( 0, this, SLOT(deactivate()) );
182 } 182 }
183 } else if ( object->inherits( "QMenuBar" ) ) { 183 } else if ( object->inherits( "QMenuBar" ) ) {
184 int dx = 0; 184 int dx = 0;
185 switch ( ke->key() ) { 185 switch ( ke->key() ) {
186 case Key_Left: 186 case Key_Left:
187 dx = -1; 187 dx = -1;
188 break; 188 break;
189 189
190 case Key_Right: 190 case Key_Right:
191 dx = 1; 191 dx = 1;
192 break; 192 break;
193 } 193 }
194 194
195 QMenuBarHack *mb = (QMenuBarHack *)object; 195 QMenuBarHack *mb = (QMenuBarHack *)object;
196 if ( dx && mb->activeItem() >= 0 ) { 196 if ( dx && mb->activeItem() >= 0 ) {
197 int i = mb->activeItem(); 197 int i = mb->activeItem();
198 int c = mb->count(); 198 int c = mb->count();
199 int n = c; 199 int n = c;
200 while ( n-- ) { 200 while ( n-- ) {
201 i = i + dx; 201 i = i + dx;
202 if ( i == c ) { 202 if ( i == c ) {
203 mb->goodbye(); 203 mb->goodbye();
204 moveFocus( TRUE ); 204 moveFocus( TRUE );
205 return TRUE; 205 return TRUE;
206 } else if ( i < 0 ) { 206 } else if ( i < 0 ) {
207 mb->goodbye(); 207 mb->goodbye();
208 moveFocus( FALSE ); 208 moveFocus( FALSE );
209 return TRUE; 209 return TRUE;
210 } 210 }
211 QMenuItem *mi = mb->findItem( mb->idAt(i) ); 211 QMenuItem *mi = mb->findItem( mb->idAt(i) );
212 if ( mi->isEnabled() && !mi->isSeparator() ) { 212 if ( mi->isEnabled() && !mi->isSeparator() ) {
213 break; 213 break;
214 } 214 }
215 } 215 }
216 } 216 }
217 } 217 }
218 } 218 }
219 if ( ke->key() == Key_F11 ) { 219 if ( ke->key() == Key_F11 ) {
220 setActive( !isActive() ); 220 setActive( !isActive() );
221 return TRUE; 221 return TRUE;
222 } 222 }
223 } else if ( event->type() == QEvent::KeyRelease ) { 223 } else if ( event->type() == QEvent::KeyRelease ) {
224 QKeyEvent *ke = (QKeyEvent *)event; 224 QKeyEvent *ke = (QKeyEvent *)event;
225 if ( isActive() ) { 225 if ( isActive() ) {
226 if ( object->inherits( "QButton" ) ) { 226 if ( object->inherits( "QButton" ) ) {
227 // Deactivate when a button is selected 227 // Deactivate when a button is selected
228 if ( ke->key() == Key_Space ) 228 if ( ke->key() == Key_Space )
229 QTimer::singleShot( 0, this, SLOT(deactivate()) ); 229 QTimer::singleShot( 0, this, SLOT(deactivate()) );
230 } 230 }
231 } 231 }
232 } else if ( event->type() == QEvent::FocusIn ) { 232 } else if ( event->type() == QEvent::FocusIn ) {
233 if ( isActive() ) { 233 if ( isActive() ) {
234 // A non-menu/tool widget has been selected - we're deactivated 234 // A non-menu/tool widget has been selected - we're deactivated
235 QWidget *w = (QWidget *)object; 235 QWidget *w = (QWidget *)object;
236 if ( !w->isPopup() && !list.contains( GuardedWidget( w ) ) ) { 236 if ( !w->isPopup() && !list.contains( GuardedWidget( w ) ) ) {
237 inFocus = 0; 237 inFocus = 0;
238 } 238 }
239 } 239 }
240 } else if ( event->type() == QEvent::Hide ) { 240 } else if ( event->type() == QEvent::Hide ) {
241 if ( isActive() ) { 241 if ( isActive() ) {
242 // Deaticvate if a menu/tool has been hidden 242 // Deaticvate if a menu/tool has been hidden
243 QWidget *w = (QWidget *)object; 243 QWidget *w = (QWidget *)object;
244 if ( !w->isPopup() && !list.contains( GuardedWidget( w ) ) ) { 244 if ( !w->isPopup() && !list.contains( GuardedWidget( w ) ) ) {
245 setActive( FALSE ); 245 setActive( FALSE );
246 } 246 }
247 } 247 }
248 } else if ( event->type() == QEvent::ChildInserted ) { 248 } else if ( event->type() == QEvent::ChildInserted ) {
249 QChildEvent *ce = (QChildEvent *)event; 249 QChildEvent *ce = (QChildEvent *)event;
250 if ( ce->child()->inherits( "QMenuBar" ) ) { 250 if ( ce->child()->inherits( "QMenuBar" ) ) {
251 addWidget( (QWidget *)ce->child() ); 251 addWidget( (QWidget *)ce->child() );
252 ce->child()->installEventFilter( this ); 252 ce->child()->installEventFilter( this );
253 } else if ( object->inherits( "QToolBar" ) && ce->child()->isWidgetType() ) { 253 } else if ( object->inherits( "QToolBar" ) && ce->child()->isWidgetType() ) {
254 addWidget( (QWidget *)ce->child() ); 254 addWidget( (QWidget *)ce->child() );
255 } 255 }
256 } else if ( event->type() == QEvent::ChildRemoved ) { 256 } else if ( event->type() == QEvent::ChildRemoved ) {
257 QChildEvent *ce = (QChildEvent *)event; 257 QChildEvent *ce = (QChildEvent *)event;
258 if ( ce->child()->inherits( "QMenuBar" ) ) { 258 if ( ce->child()->inherits( "QMenuBar" ) ) {
259 removeWidget( (QWidget *)ce->child() ); 259 removeWidget( (QWidget *)ce->child() );
260 ce->child()->removeEventFilter( this ); 260 ce->child()->removeEventFilter( this );
261 } else if ( object->inherits( "QToolBar" ) && ce->child()->isWidgetType() ) { 261 } else if ( object->inherits( "QToolBar" ) && ce->child()->isWidgetType() ) {
262 removeWidget( (QWidget *)ce->child() ); 262 removeWidget( (QWidget *)ce->child() );
263 } 263 }
264 } 264 }
265 265
266 return FALSE; 266 return FALSE;
267} 267}
268 268
269void QPEMenuToolFocusManager::deactivate() 269void QPEMenuToolFocusManager::deactivate()
270{ 270{
271 setActive( FALSE ); 271 setActive( FALSE );
272} 272}
273 273
274/*! 274/*!
275 \class QPEMenuBar qpemenubar.h 275 \class QPEMenuBar qpemenubar.h
276 \brief The QPEMenuBar class is obsolete. Use QMenuBar instead. 276 \brief The QPEMenuBar class is obsolete. Use QMenuBar instead.
277 277
278 \obsolete 278 \obsolete
279 279
280 This class is obsolete. Use QMenuBar instead. 280 This class is obsolete. Use QMenuBar instead.
281 281
282 \sa QMenuBar 282 \sa QMenuBar
283*/ 283*/
284 284
285/*! 285/*!
286 Constructs a QPEMenuBar just as you would construct 286 Constructs a QPEMenuBar just as you would construct
287 a QMenuBar, passing \a parent and \a name. 287 a QMenuBar, passing \a parent and \a name.
288*/ 288*/
289QPEMenuBar::QPEMenuBar( QWidget *parent, const char *name ) 289QPEMenuBar::QPEMenuBar( QWidget *parent, const char *name )
290 : QMenuBar( parent, name ) 290 : QMenuBar( parent, name )
291{ 291{
292} 292}
293 293
294/*! 294/*!
295 \reimp 295 \reimp
296*/ 296*/
297QPEMenuBar::~QPEMenuBar() 297QPEMenuBar::~QPEMenuBar()
298{ 298{
299} 299}
300 300
301/*! 301/*!
302 \internal 302 \internal
303*/ 303*/
304void QPEMenuBar::keyPressEvent( QKeyEvent *e ) 304void QPEMenuBar::keyPressEvent( QKeyEvent *e )
305{ 305{
306 QMenuBar::keyPressEvent( e ); 306 QMenuBar::keyPressEvent( e );
307} 307}
308 308
309
310void QPEMenuBar::activateItem( int index )
311{
312 activateItemAt( index );
313}
314
315void QPEMenuBar::goodbye()
316{
317 activateItemAt(-1);
318 for ( unsigned int i = 0; i < count(); i++ ) {
319 QMenuItem *mi = findItem( idAt(i) );
320 if ( mi->popup() ) {
321 mi->popup()->hide();
322 }
323 }
324}
diff --git a/library/qpemenubar.h b/library/qpemenubar.h
index 736b12b..5bfbe83 100644
--- a/library/qpemenubar.h
+++ b/library/qpemenubar.h
@@ -1,71 +1,73 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2001 Trolltech AS. All rights reserved. 2** Copyright (C) 2001 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qtopia Environment. 4** This file is part of Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20 20
21#ifndef QPEMENUBAR_H 21#ifndef QPEMENUBAR_H
22#define QPEMENUBAR_H 22#define QPEMENUBAR_H
23 23
24#include <qmenubar.h> 24#include <qmenubar.h>
25#include <qguardedptr.h> 25#include <qguardedptr.h>
26#include <qvaluelist.h> 26#include <qvaluelist.h>
27 27
28class QPEMenuToolFocusManager : public QObject 28class QPEMenuToolFocusManager : public QObject
29{ 29{
30 Q_OBJECT 30 Q_OBJECT
31public: 31public:
32 QPEMenuToolFocusManager(); 32 QPEMenuToolFocusManager();
33 33
34 void addWidget( QWidget *w ); 34 void addWidget( QWidget *w );
35 void removeWidget( QWidget *w ); 35 void removeWidget( QWidget *w );
36 void setActive( bool a ); 36 void setActive( bool a );
37 bool isActive() const; 37 bool isActive() const;
38 void moveFocus( bool next ); 38 void moveFocus( bool next );
39 39
40 static QPEMenuToolFocusManager *manager(); 40 static QPEMenuToolFocusManager *manager();
41 static void initialize(); 41 static void initialize();
42 42
43protected: 43protected:
44 void setFocus( QWidget *w, bool next=TRUE ); 44 void setFocus( QWidget *w, bool next=TRUE );
45 bool eventFilter( QObject *object, QEvent *event ); 45 bool eventFilter( QObject *object, QEvent *event );
46 46
47private slots: 47private slots:
48 void deactivate(); 48 void deactivate();
49 49
50private: 50private:
51 typedef QGuardedPtr<QWidget> GuardedWidget; 51 typedef QGuardedPtr<QWidget> GuardedWidget;
52 QValueList<GuardedWidget> list; 52 QValueList<GuardedWidget> list;
53 GuardedWidget inFocus; 53 GuardedWidget inFocus;
54 GuardedWidget oldFocus; 54 GuardedWidget oldFocus;
55 static QPEMenuToolFocusManager *me; 55 static QPEMenuToolFocusManager *me;
56}; 56};
57 57
58 58
59class QPEMenuBar : public QMenuBar 59class QPEMenuBar : public QMenuBar
60{ 60{
61 Q_OBJECT 61 Q_OBJECT
62public: 62public:
63 QPEMenuBar( QWidget *parent=0, const char* name=0 ); 63 QPEMenuBar( QWidget *parent=0, const char* name=0 );
64 ~QPEMenuBar(); 64 ~QPEMenuBar();
65 65
66protected: 66protected:
67 virtual void keyPressEvent( QKeyEvent *e ); 67 virtual void keyPressEvent( QKeyEvent *e );
68 void activateItem( int index );
69 void goodbye();
68}; 70};
69 71
70#endif 72#endif
71 73