diff options
author | Mikolaj Boc <mikolaj.boc@qt.io> | 2023-02-02 08:58:19 +0100 |
---|---|---|
committer | Mikolaj Boc <mikolaj.boc@qt.io> | 2023-02-04 21:38:33 +0100 |
commit | ae51eeb0bb46e6fa21747a4a6f1e33b9a88c39bd (patch) | |
tree | c638adf1ca69ca7226c5f3e60692ee94b5eb1894 /src/plugins/platforms | |
parent | 9ea00c70fbbe61d4c2da98c3d9390bfbada157bd (diff) |
Support Qt::WindowMaximizeButtonHint in QWasmWindow
Change-Id: I1089ab4706c4342fa5976b1aff18d67d47769687
Reviewed-by: Aleksandr Reviakin <aleksandr.reviakin@qt.io>
Reviewed-by: Morten Johan Sørvig <morten.sorvig@qt.io>
Diffstat (limited to 'src/plugins/platforms')
-rw-r--r-- | src/plugins/platforms/wasm/qwasmwindow.cpp | 9 | ||||
-rw-r--r-- | src/plugins/platforms/wasm/qwasmwindow.h | 1 |
2 files changed, 9 insertions, 1 deletions
diff --git a/src/plugins/platforms/wasm/qwasmwindow.cpp b/src/plugins/platforms/wasm/qwasmwindow.cpp index a25be3490c..06d9108866 100644 --- a/src/plugins/platforms/wasm/qwasmwindow.cpp +++ b/src/plugins/platforms/wasm/qwasmwindow.cpp @@ -362,6 +362,8 @@ void QWasmWindow::setWindowFlags(Qt::WindowFlags flags) dom::syncCSSClassWith(m_qtWindow, "has-shadow", !flags.testFlag(Qt::NoDropShadowWindowHint)); dom::syncCSSClassWith(m_qtWindow, "transparent-for-input", flags.testFlag(Qt::WindowTransparentForInput)); + + m_nonClientArea->titleBar()->setMaximizeVisible(hasMaximizeButton()); } void QWasmWindow::setWindowState(Qt::WindowStates newState) @@ -422,7 +424,7 @@ void QWasmWindow::applyWindowState() dom::syncCSSClassWith(m_qtWindow, "maximized", isMaximized); m_nonClientArea->titleBar()->setRestoreVisible(isMaximized); - m_nonClientArea->titleBar()->setMaximizeVisible(!isMaximized); + m_nonClientArea->titleBar()->setMaximizeVisible(hasMaximizeButton()); if (isVisible()) QWindowSystemInterface::handleWindowStateChanged(window(), m_state, m_previousWindowState); @@ -521,6 +523,11 @@ bool QWasmWindow::hasTitleBar() const && !windowIsPopupType(m_flags); } +bool QWasmWindow::hasMaximizeButton() const +{ + return !m_state.testFlag(Qt::WindowMaximized) && m_flags.testFlag(Qt::WindowMaximizeButtonHint); +} + bool QWasmWindow::windowIsPopupType(Qt::WindowFlags flags) const { if (flags.testFlag(Qt::Tool)) diff --git a/src/plugins/platforms/wasm/qwasmwindow.h b/src/plugins/platforms/wasm/qwasmwindow.h index 7f4047b758..6c1c4a5adb 100644 --- a/src/plugins/platforms/wasm/qwasmwindow.h +++ b/src/plugins/platforms/wasm/qwasmwindow.h @@ -92,6 +92,7 @@ private: void invalidate(); bool hasTitleBar() const; + bool hasMaximizeButton() const; void applyWindowState(); bool processPointer(const PointerEvent &event); |