diff options
-rw-r--r-- | src/gui/kernel/qguiapplication.cpp | 9 | ||||
-rw-r--r-- | src/gui/kernel/qplatformwindow.cpp | 13 | ||||
-rw-r--r-- | src/gui/kernel/qplatformwindow.h | 1 | ||||
-rw-r--r-- | src/plugins/platforms/windows/qwindowswindow.cpp | 16 | ||||
-rw-r--r-- | src/plugins/platforms/windows/qwindowswindow.h | 1 | ||||
-rw-r--r-- | src/widgets/kernel/qapplication.cpp | 8 |
6 files changed, 46 insertions, 2 deletions
diff --git a/src/gui/kernel/qguiapplication.cpp b/src/gui/kernel/qguiapplication.cpp index 85297dda1c..5f4cbce73b 100644 --- a/src/gui/kernel/qguiapplication.cpp +++ b/src/gui/kernel/qguiapplication.cpp @@ -604,8 +604,13 @@ QWindowList QGuiApplication::topLevelWindows() const QWindowList &list = QGuiApplicationPrivate::window_list; QWindowList topLevelWindows; for (int i = 0; i < list.size(); i++) { - if (!list.at(i)->parent()) - topLevelWindows.prepend(list.at(i)); + if (!list.at(i)->parent()) { + // Top windows of embedded QAxServers do not have QWindow parents, + // but they are not true top level windows, so do not include them. + const bool embedded = list.at(i)->handle() && list.at(i)->handle()->isEmbedded(0); + if (!embedded) + topLevelWindows.prepend(list.at(i)); + } } return topLevelWindows; } diff --git a/src/gui/kernel/qplatformwindow.cpp b/src/gui/kernel/qplatformwindow.cpp index d79884a1db..748a7825b6 100644 --- a/src/gui/kernel/qplatformwindow.cpp +++ b/src/gui/kernel/qplatformwindow.cpp @@ -175,6 +175,19 @@ bool QPlatformWindow::isActive() const } /*! + Returns true if the window is a descendant of an embedded non-Qt window. + Example of an embedded non-Qt window is the parent window of an in-process QAxServer. + + If \a parentWindow is nonzero, only check if the window is embedded in the + specified \a parentWindow. +*/ +bool QPlatformWindow::isEmbedded(const QPlatformWindow *parentWindow) const +{ + Q_UNUSED(parentWindow); + return false; +} + +/*! Requests setting the window state of this surface to \a type. Returns the actual state set. diff --git a/src/gui/kernel/qplatformwindow.h b/src/gui/kernel/qplatformwindow.h index a6a519e6fd..e27851830e 100644 --- a/src/gui/kernel/qplatformwindow.h +++ b/src/gui/kernel/qplatformwindow.h @@ -103,6 +103,7 @@ public: virtual bool isExposed() const; virtual bool isActive() const; + virtual bool isEmbedded(const QPlatformWindow *parentWindow) const; virtual void propagateSizeHints(); diff --git a/src/plugins/platforms/windows/qwindowswindow.cpp b/src/plugins/platforms/windows/qwindowswindow.cpp index 8f376162ef..7e79e1c819 100644 --- a/src/plugins/platforms/windows/qwindowswindow.cpp +++ b/src/plugins/platforms/windows/qwindowswindow.cpp @@ -424,6 +424,7 @@ QWindowsWindow::WindowData if (desktop) { // desktop widget. No frame, hopefully? result.hwnd = GetDesktopWindow(); result.geometry = frameGeometry(result.hwnd, true); + result.embedded = false; if (QWindowsContext::verboseWindows) qDebug().nospace() << "Created desktop window " << w << result.hwnd; return result; @@ -830,6 +831,21 @@ bool QWindowsWindow::isActive() const return false; } +bool QWindowsWindow::isEmbedded(const QPlatformWindow *parentWindow) const +{ + if (parentWindow) { + const QWindowsWindow *ww = static_cast<const QWindowsWindow *>(parentWindow); + const HWND hwnd = ww->handle(); + if (!IsChild(hwnd, m_data.hwnd)) + return false; + } + + if (!m_data.embedded && parent()) + return parent()->isEmbedded(0); + + return m_data.embedded; +} + // partially from QWidgetPrivate::show_sys() void QWindowsWindow::show_sys() const { diff --git a/src/plugins/platforms/windows/qwindowswindow.h b/src/plugins/platforms/windows/qwindowswindow.h index 8e6ff9f891..35790e2739 100644 --- a/src/plugins/platforms/windows/qwindowswindow.h +++ b/src/plugins/platforms/windows/qwindowswindow.h @@ -154,6 +154,7 @@ public: virtual void setVisible(bool visible); bool isVisible() const; virtual bool isActive() const; + virtual bool isEmbedded(const QPlatformWindow *parentWindow) const; virtual Qt::WindowFlags setWindowFlags(Qt::WindowFlags flags); virtual Qt::WindowState setWindowState(Qt::WindowState state); diff --git a/src/widgets/kernel/qapplication.cpp b/src/widgets/kernel/qapplication.cpp index 254e4c4383..1fcd7b1fbc 100644 --- a/src/widgets/kernel/qapplication.cpp +++ b/src/widgets/kernel/qapplication.cpp @@ -106,6 +106,7 @@ extern bool qt_wince_is_pocket_pc(); //qguifunctions_wince.cpp #endif #include "qdatetime.h" +#include <qpa/qplatformwindow.h> //#define ALIEN_DEBUG @@ -2317,6 +2318,13 @@ bool QApplicationPrivate::isWindowBlocked(QWindow *window, QWindow **blockingWin p = w->transientParent(); w = p; } + + // Embedded in-process windows are not visible in normal parent-child chain, + // so check the native parent chain, too. + const QPlatformWindow *platWin = window->handle(); + const QPlatformWindow *modalPlatWin = modalWindow->handle(); + if (platWin && modalPlatWin && platWin->isEmbedded(modalPlatWin)) + return false; } Qt::WindowModality windowModality = modalWindow->windowModality(); |