From ec393e4a90e8e9f33299c6eb0189503e7771c4c0 Mon Sep 17 00:00:00 2001 From: Joshua Minter Date: Wed, 4 Jul 2018 10:15:19 +1000 Subject: [PATCH] Disable maximize button on non-resizable windows (#588) * Disabled maximize button When creating a non resizable window in win32. Also added example code to test. * Added to changelog * Added to documentation * Removed non_resizable test * Other suggested PR changes * Documentation changes * CHANGELOG nits --- CHANGELOG.md | 2 ++ src/platform/windows/window.rs | 12 +++++++----- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 987d42d5..2f02f2e1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,7 @@ # Unreleased +- On Windows, non-resizable windows now have the maximization button disabled. This is consistent with behavior on macOS and popular X11 WMs. + # Version 0.16.1 (2018-07-02) - Added logging through `log`. Logging will become more extensive over time. diff --git a/src/platform/windows/window.rs b/src/platform/windows/window.rs index d5f93e7f..f257c165 100644 --- a/src/platform/windows/window.rs +++ b/src/platform/windows/window.rs @@ -33,6 +33,8 @@ use platform::platform::monitor::get_available_monitors; use platform::platform::raw_input::register_all_mice_and_keyboards_for_raw_input; use platform::platform::util; +const WS_RESIZABLE: DWORD = winuser::WS_SIZEBOX | winuser::WS_MAXIMIZEBOX; + /// The Win32 implementation of the main `Window` object. pub struct Window { /// Main handle for the window. @@ -294,9 +296,9 @@ impl Window { winuser::GetWindowLongW(self.window.0, winuser::GWL_STYLE) }; if resizable { - style |= winuser::WS_SIZEBOX as LONG; + style |= WS_RESIZABLE as LONG; } else { - style &= !winuser::WS_SIZEBOX as LONG; + style &= !WS_RESIZABLE as LONG; } unsafe { @@ -544,9 +546,9 @@ impl Window { let _ = Self::grab_cursor_inner(&window, false); if resizable { - style |= winuser::WS_SIZEBOX as LONG; + style |= WS_RESIZABLE as LONG; } else { - style &= !winuser::WS_SIZEBOX as LONG; + style &= !WS_RESIZABLE as LONG; } winuser::SetWindowLongW(window.0, winuser::GWL_STYLE, style); winuser::SetWindowLongW(window.0, winuser::GWL_EXSTYLE, ex_style); @@ -951,7 +953,7 @@ unsafe fn init( }; if !attributes.resizable { - style &= !winuser::WS_SIZEBOX; + style &= !WS_RESIZABLE; } if pl_attribs.parent.is_some() {