summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSergio Martins <sergio.martins.qnx@kdab.com>2012-11-16 16:31:49 +0000
committerThe Qt Project <gerrit-noreply@qt-project.org>2012-11-28 16:21:57 +0100
commit779ef8bb7e714eef8d48298f641a046e3d25a881 (patch)
tree2bf8a03d4882c20ea97189c2c22124225bf42fee
parentbc6228c3f410a51db9aaa97b6ce3f5f7093ffc20 (diff)
QNX: Fix window focus problems when using QNX 6.5.0.
In blackberry, activation events come through the navigator, but we might not have a navigator. Change-Id: I0d9e1a08336aa403035fdf00be46d839a83f4b58 Reviewed-by: Kevin Krammer <kevin.krammer@kdab.com> Reviewed-by: Sean Harmer <sean.harmer@kdab.com>
-rw-r--r--src/plugins/platforms/qnx/qqnxintegration.cpp6
-rw-r--r--src/plugins/platforms/qnx/qqnxintegration.h2
-rw-r--r--src/plugins/platforms/qnx/qqnxscreeneventhandler.cpp5
3 files changed, 13 insertions, 0 deletions
diff --git a/src/plugins/platforms/qnx/qqnxintegration.cpp b/src/plugins/platforms/qnx/qqnxintegration.cpp
index d35ec935fd..e594ea952d 100644
--- a/src/plugins/platforms/qnx/qqnxintegration.cpp
+++ b/src/plugins/platforms/qnx/qqnxintegration.cpp
@@ -518,4 +518,10 @@ QQnxScreen *QQnxIntegration::primaryDisplay() const
return m_screens.first();
}
+bool QQnxIntegration::supportsNavigatorEvents() const
+{
+ // If QQNX_PPS or Q_OS_BLACKBERRY is defined then we have navigator
+ return m_navigator != 0;
+}
+
QT_END_NAMESPACE
diff --git a/src/plugins/platforms/qnx/qqnxintegration.h b/src/plugins/platforms/qnx/qqnxintegration.h
index 441e2c9d68..97a5e631e8 100644
--- a/src/plugins/platforms/qnx/qqnxintegration.h
+++ b/src/plugins/platforms/qnx/qqnxintegration.h
@@ -98,6 +98,8 @@ public:
void moveToScreen(QWindow *window, int screen);
+ bool supportsNavigatorEvents() const;
+
QAbstractEventDispatcher *guiThreadEventDispatcher() const;
QPlatformFontDatabase *fontDatabase() const { return m_fontDatabase; }
diff --git a/src/plugins/platforms/qnx/qqnxscreeneventhandler.cpp b/src/plugins/platforms/qnx/qqnxscreeneventhandler.cpp
index d8712bf569..8b41465add 100644
--- a/src/plugins/platforms/qnx/qqnxscreeneventhandler.cpp
+++ b/src/plugins/platforms/qnx/qqnxscreeneventhandler.cpp
@@ -276,6 +276,11 @@ void QQnxScreenEventHandler::handlePointerEvent(screen_event_t event)
qScreenEventDebug() << Q_FUNC_INFO << "Qt enter, w=" << w;
}
}
+
+ // If we don't have a navigator, we don't get activation events.
+ if (buttonState && w && w != QGuiApplication::focusWindow() && !m_qnxIntegration->supportsNavigatorEvents())
+ QWindowSystemInterface::handleWindowActivated(w);
+
m_lastMouseWindow = qnxWindow;
// Apply scaling to wheel delta and invert value for Qt. We'll probably want to scale