[gtk/wip.win32.fixes: 151/151] gdksurface-win32.c: Disable AeroSnap for surface if not resizable
- From: Chun-wei Fan <fanchunwei src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/wip.win32.fixes: 151/151] gdksurface-win32.c: Disable AeroSnap for surface if not resizable
- Date: Fri, 23 Jul 2021 10:45:23 +0000 (UTC)
commit 695fba23d0261bdd9a32b55e78e7b7d9241e5f71
Author: Chun-wei Fan <fanchunwei src gnome org>
Date: Fri Jul 2 15:05:33 2021 +0800
gdksurface-win32.c: Disable AeroSnap for surface if not resizable
AeroSnap essentially resizes the surface by all means, so if a surface
is not resizable, just bail out of the operation, even though it is
triggered by a move operation.
This matches what is done in Windows.
gdk/win32/gdksurface-win32.c | 8 ++++++++
1 file changed, 8 insertions(+)
---
diff --git a/gdk/win32/gdksurface-win32.c b/gdk/win32/gdksurface-win32.c
index fca99e3893..6b6c6b6a32 100644
--- a/gdk/win32/gdksurface-win32.c
+++ b/gdk/win32/gdksurface-win32.c
@@ -3231,6 +3231,14 @@ handle_aerosnap_move_resize (GdkSurface *window,
int halfright = 0;
int fullup = 0;
gboolean fullup_edge = FALSE;
+ GdkWin32Surface *impl = GDK_WIN32_SURFACE (window);
+
+ if (context->op == GDK_WIN32_DRAGOP_MOVE)
+ {
+ if (impl->toplevel_layout != NULL &&
+ !gdk_toplevel_layout_get_resizable (impl->toplevel_layout))
+ return;
+ }
if (context->op == GDK_WIN32_DRAGOP_RESIZE)
switch (context->edge)
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]