diff options
author | Jason Barron <jbarron@trolltech.com> | 2009-06-16 09:45:30 (GMT) |
---|---|---|
committer | Jason Barron <jbarron@trolltech.com> | 2009-06-16 09:55:51 (GMT) |
commit | 9d78e1132427ec803f08b2861ab27587ca72cfbf (patch) | |
tree | 181989d7442cd81fd975ae8d3f45aa184f4804cb /src/gui/kernel/qapplication_s60.cpp | |
parent | 18fcfc3576b7bcbcf3326697461f21fab990512b (diff) | |
download | Qt-9d78e1132427ec803f08b2861ab27587ca72cfbf.zip Qt-9d78e1132427ec803f08b2861ab27587ca72cfbf.tar.gz Qt-9d78e1132427ec803f08b2861ab27587ca72cfbf.tar.bz2 |
Update softkeys correctly when no focus widget is present.
In the case where there is no focus widget present, the button group
container should be updated with the softkeys from the currently active
window if it has softkeys. This patch enables this behavior.
Also modify QMainWindow such that the soft keys are updated when the
main window becomes the active window and not only when the menu bar
is set. At the moment, this creates a new QAction and this should be
changed since it will continuously grow the memory.
As a final fix, move the soft key setting out of setFocus() because it
is much to early. At the point, the widget does not know for certain
that it actually will get focus since it could be disabled or have a
focus proxy.
Diffstat (limited to 'src/gui/kernel/qapplication_s60.cpp')
-rw-r--r-- | src/gui/kernel/qapplication_s60.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/src/gui/kernel/qapplication_s60.cpp b/src/gui/kernel/qapplication_s60.cpp index 4c008fb..42faf98 100644 --- a/src/gui/kernel/qapplication_s60.cpp +++ b/src/gui/kernel/qapplication_s60.cpp @@ -1072,9 +1072,10 @@ void QApplication::symbianHandleCommand(int command) default: if (command >= SOFTKEYSTART && command <= SOFTKEYEND) { int index= command-SOFTKEYSTART; - QWidget* focused = QApplication::focusWidget(); - const QList<QAction*>& softKeys = focused->softKeys(); - Q_ASSERT(index<softKeys.count()); + QWidget *focused = QApplication::focusWidget(); + QWidget *softKeySource = focused ? focused : QApplication::activeWindow(); + const QList<QAction*>& softKeys = softKeySource->softKeys(); + Q_ASSERT(index < softKeys.count()); softKeys.at(index)->activate(QAction::Trigger); } else |