From e2f57d59d814128c5b07f26b368ea07019e154f7 Mon Sep 17 00:00:00 2001 From: Friedemann Kleint Date: Mon, 11 Jun 2012 16:13:24 +0200 Subject: [PATCH] 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 --- src/widgets/kernel/qapplication.cpp | 2 +- src/widgets/kernel/qapplication_p.h | 2 +- src/widgets/kernel/qwidgetwindow_qpa.cpp | 10 ++++++++-- 3 files changed, 10 insertions(+), 4 deletions(-) diff --git a/src/widgets/kernel/qapplication.cpp b/src/widgets/kernel/qapplication.cpp index 0553dab..7999eeb 100644 --- a/src/widgets/kernel/qapplication.cpp +++ b/src/widgets/kernel/qapplication.cpp @@ -3972,7 +3972,7 @@ bool QApplicationPrivate::notify_helper(QObject *receiver, QEvent * e) \snippet code/src_gui_kernel_qapplication.cpp 13 */ -bool QApplicationPrivate::inPopupMode() const +bool QApplicationPrivate::inPopupMode() { return QApplicationPrivate::popupWidgets != 0; } diff --git a/src/widgets/kernel/qapplication_p.h b/src/widgets/kernel/qapplication_p.h index f700851..1e57055 100644 --- a/src/widgets/kernel/qapplication_p.h +++ b/src/widgets/kernel/qapplication_p.h @@ -170,7 +170,7 @@ public: static void x11_initialize_style(); #endif - bool inPopupMode() const; + static bool inPopupMode(); void closePopup(QWidget *popup); void openPopup(QWidget *popup); static void setFocusWidget(QWidget *focus, Qt::FocusReason reason); diff --git a/src/widgets/kernel/qwidgetwindow_qpa.cpp b/src/widgets/kernel/qwidgetwindow_qpa.cpp index 21a0ada..7ae0a5b 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); } -- 2.7.4