Android: handle keyPress event for Key_Back

Added logic so that accepting either the press or the release will
keep the app running. This makes it possible to use the onBackPressed
functionality in QML.

This functionality is only intended for running in a complete Android
environment, so make sure that we don't terminate the application in
the NO_SDK case.

Task-number: QTBUG-30803

Change-Id: I2546eea73bf6a6ee8b196125b7556479b9b10a9c
Reviewed-by: BogDan Vatra <bogdan@kde.org>
This commit is contained in:
Paul Olav Tvete 2013-04-23 10:47:55 +02:00 committed by The Qt Project
parent 472e448d6a
commit fc98d027c0

View File

@ -1666,41 +1666,36 @@ void QGuiApplicationPrivate::processKeyEvent(QWindowSystemInterfacePrivate::KeyE
QWindow *window = e->window.data(); QWindow *window = e->window.data();
modifier_buttons = e->modifiers; modifier_buttons = e->modifiers;
if (e->nullWindow if (e->nullWindow
#ifdef Q_OS_ANDROID #if defined(Q_OS_ANDROID) && !defined(Q_OS_ANDROID_NO_SDK)
|| (e->keyType == QEvent::KeyRelease && e->key == Qt::Key_Back) || e->key == Qt::Key_Menu || e->key == Qt::Key_Back || e->key == Qt::Key_Menu
#endif #endif
) { ) {
window = QGuiApplication::focusWindow(); window = QGuiApplication::focusWindow();
} }
if (!window
#ifdef Q_OS_ANDROID
&& e->keyType != QEvent::KeyRelease && e->key != Qt::Key_Back
#endif
) {
return;
}
if (window && window->d_func()->blockedByModalWindow) {
// a modal window is blocking this window, don't allow key events through
return;
}
QKeyEvent ev(e->keyType, e->key, e->modifiers, QKeyEvent ev(e->keyType, e->key, e->modifiers,
e->nativeScanCode, e->nativeVirtualKey, e->nativeModifiers, e->nativeScanCode, e->nativeVirtualKey, e->nativeModifiers,
e->unicode, e->repeat, e->repeatCount); e->unicode, e->repeat, e->repeatCount);
ev.setTimestamp(e->timestamp); ev.setTimestamp(e->timestamp);
#ifdef Q_OS_ANDROID // only deliver key events when we have a window, and no modal window is blocking this window
if (e->keyType == QEvent::KeyRelease && e->key == Qt::Key_Back) {
if (!window) { if (window && !window->d_func()->blockedByModalWindow)
qApp->quit();
} else {
QGuiApplication::sendEvent(window, &ev);
if (!ev.isAccepted() && e->key == Qt::Key_Back)
QWindowSystemInterface::handleCloseEvent(window);
}
} else
#endif
QGuiApplication::sendSpontaneousEvent(window, &ev); QGuiApplication::sendSpontaneousEvent(window, &ev);
#if defined(Q_OS_ANDROID) && !defined(Q_OS_ANDROID_NO_SDK)
else
ev.setAccepted(false);
static bool backKeyPressAccepted = false;
if (e->keyType == QEvent::KeyPress) {
backKeyPressAccepted = e->key == Qt::Key_Back && ev.isAccepted();
} else if (e->keyType == QEvent::KeyRelease && e->key == Qt::Key_Back && !backKeyPressAccepted && !ev.isAccepted()) {
if (!window)
qApp->quit();
else
QWindowSystemInterface::handleCloseEvent(window);
}
#endif
} }
void QGuiApplicationPrivate::processEnterEvent(QWindowSystemInterfacePrivate::EnterEvent *e) void QGuiApplicationPrivate::processEnterEvent(QWindowSystemInterfacePrivate::EnterEvent *e)