diff options
| author | Friedemann Kleint <[email protected]> | 2012-06-11 16:13:24 +0200 |
|---|---|---|
| committer | Qt by Nokia <[email protected]> | 2012-06-13 02:29:46 +0200 |
| commit | e2f57d59d814128c5b07f26b368ea07019e154f7 (patch) | |
| tree | e7f415c88f89c496b3f08bc5fad724a0fef30628 /src/widgets/kernel/qwidgetwindow_qpa.cpp | |
| parent | ef459193ec927f347a2c91b180994428c6ea1a97 (diff) | |
Send key events to pop-up widget in case there is one.
Make QApplicationPrivate::inPopupMode() static for
convenience.
Task-number: QTBUG-26095
Change-Id: I98dc1e40d357592b790cd51d7aca60c2be9f380f
Reviewed-by: Girish Ramakrishnan <[email protected]>
Diffstat (limited to 'src/widgets/kernel/qwidgetwindow_qpa.cpp')
| -rw-r--r-- | src/widgets/kernel/qwidgetwindow_qpa.cpp | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/src/widgets/kernel/qwidgetwindow_qpa.cpp b/src/widgets/kernel/qwidgetwindow_qpa.cpp index 21a0ada831d..7ae0a5bf760 100644 --- a/src/widgets/kernel/qwidgetwindow_qpa.cpp +++ b/src/widgets/kernel/qwidgetwindow_qpa.cpp @@ -342,8 +342,14 @@ void QWidgetWindow::handleKeyEvent(QKeyEvent *event) if (QApplicationPrivate::instance()->modalState() && !qt_try_modal(m_widget, event->type())) return; - QObject *receiver = focusObject(); - + QObject *receiver = 0; + if (QApplicationPrivate::inPopupMode()) { + QWidget *popup = QApplication::activePopupWidget(); + QWidget *popupFocusWidget = popup->focusWidget(); + receiver = popupFocusWidget ? popupFocusWidget : popup; + } + if (!receiver) + receiver = focusObject(); QGuiApplication::sendSpontaneousEvent(receiver, event); } |
