summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLorn Potter <lorn.potter@gmail.com>2022-04-27 11:21:36 +1000
committerLorn Potter <lorn.potter@gmail.com>2022-06-22 20:04:35 +1000
commitcf9cd8cc081397d08f48b6ae0d9380b11f4929dd (patch)
tree0f3e857cf91d511dbc9d53e37b43159da6084821
parente114fec62adf13b8c21ca890fb748cb27f391c25 (diff)
wasm: do not allow blocked windows to be resized
Fixes: QTBUG-102869 Pick-to: 6.3 6.4 Change-Id: I69a4afbb67618dce7bcc499208e7e608e9adf212 Reviewed-by: David Skoland <david.skoland@qt.io>
-rw-r--r--src/plugins/platforms/wasm/qwasmcompositor.cpp15
1 files changed, 10 insertions, 5 deletions
diff --git a/src/plugins/platforms/wasm/qwasmcompositor.cpp b/src/plugins/platforms/wasm/qwasmcompositor.cpp
index 676ed6c4d0..7787367e01 100644
--- a/src/plugins/platforms/wasm/qwasmcompositor.cpp
+++ b/src/plugins/platforms/wasm/qwasmcompositor.cpp
@@ -995,6 +995,7 @@ bool QWasmCompositor::processMouse(int eventType, const EmscriptenMouseEvent *mo
QPoint localPoint = window2->mapFromGlobal(globalPoint);
bool interior = window2->geometry().contains(globalPoint);
+ bool blocked = QGuiApplicationPrivate::instance()->isWindowBlocked(window2);
if (mouseInCanvas) {
if (windowUnderMouse != window2 && interior) {
@@ -1005,6 +1006,10 @@ bool QWasmCompositor::processMouse(int eventType, const EmscriptenMouseEvent *mo
}
QWasmWindow *htmlWindow = static_cast<QWasmWindow*>(window2->handle());
+ Qt::WindowStates windowState = htmlWindow->window()->windowState();
+ bool isResizable = !(windowState.testFlag(Qt::WindowMaximized) ||
+ windowState.testFlag(Qt::WindowFullScreen));
+
switch (eventType) {
case EMSCRIPTEN_EVENT_MOUSEDOWN:
{
@@ -1024,8 +1029,10 @@ bool QWasmCompositor::processMouse(int eventType, const EmscriptenMouseEvent *mo
// 2 = right mouse button, usually right click
// from: https://w3c.github.io/uievents/#dom-mouseevent-button
if (mouseEvent->button == 0) {
- if (!(htmlWindow->m_windowState & Qt::WindowFullScreen) && !(htmlWindow->m_windowState & Qt::WindowMaximized)) {
- if (htmlWindow && window2->flags().testFlag(Qt::WindowTitleHint) && htmlWindow->isPointOnTitle(globalPoint))
+ if (!blocked && !(htmlWindow->m_windowState & Qt::WindowFullScreen)
+ && !(htmlWindow->m_windowState & Qt::WindowMaximized)) {
+ if (htmlWindow && window2->flags().testFlag(Qt::WindowTitleHint)
+ && htmlWindow->isPointOnTitle(globalPoint))
draggedWindow = window2;
else if (htmlWindow && htmlWindow->isPointOnResizeRegion(globalPoint)) {
draggedWindow = window2;
@@ -1068,11 +1075,9 @@ bool QWasmCompositor::processMouse(int eventType, const EmscriptenMouseEvent *mo
if (htmlWindow && pressedButtons.testFlag(Qt::NoButton)) {
- Qt::WindowStates windowState = htmlWindow->window()->windowState();
- bool isResizable = !(windowState.testFlag(Qt::WindowMaximized) || windowState.testFlag(Qt::WindowFullScreen));
bool isOnResizeRegion = htmlWindow->isPointOnResizeRegion(globalPoint);
- if (isResizable && isOnResizeRegion) {
+ if (isResizable && isOnResizeRegion && !blocked) {
QCursor resizingCursor = eventTranslator->cursorForMode(htmlWindow->resizeModeAtPoint(globalPoint));
if (resizingCursor != window2->cursor()) {