[gimp] Issue #5475: Tablet pointer offset malfunction with scale ratio + …



commit 208921706a5d4f279e246247979a6bf611c2afd8
Author: Jehan <jehan girinstud io>
Date:   Tue Apr 27 14:22:39 2021 +0200

    Issue #5475: Tablet pointer offset malfunction with scale ratio + …
    
    … multi-monitor
    
    Test the patch gtk!3275 on our development releases for validation.

 .../patches/gtk3-24-mr3275-gimp-issue-5475.patch   | 51 ++++++++++++++++++++++
 1 file changed, 51 insertions(+)
---
diff --git a/build/windows/patches/gtk3-24-mr3275-gimp-issue-5475.patch 
b/build/windows/patches/gtk3-24-mr3275-gimp-issue-5475.patch
new file mode 100644
index 0000000000..8929e24d22
--- /dev/null
+++ b/build/windows/patches/gtk3-24-mr3275-gimp-issue-5475.patch
@@ -0,0 +1,51 @@
+From feb4f26b5c643382241aa995034fb36b02a21a4d Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?=D0=A0=D1=83=D1=81=D0=BB=D0=B0=D0=BD=20=D0=98=D0=B6=D0=B1?=
+ =?UTF-8?q?=D1=83=D0=BB=D0=B0=D1=82=D0=BE=D0=B2?= <lrn1986 gmail com>
+Date: Mon, 8 Mar 2021 14:10:56 +0000
+Subject: [PATCH] GDK W32: Use PROCESS_PER_MONITOR_DPI_AWARE
+
+According to Microsoft documentation, PROCESS_SYSTEM_DPI_AWARE, just as
+PROCESS_DPI_UNAWARE, allows Windows to scale GTK windows and do all kinds
+of stuff. To ensure this doesn't happen, we need to use PROCESS_PER_MONITOR_DPI_AWARE,
+even if GTK does not really handle DPI changes dynamically via the  WM_DPICHANGED
+message.
+
+This completely prevents Windows from scaling GTK windows when they are moved
+between screens with different scaling set up.
+---
+ gdk/win32/gdkdisplay-win32.c | 8 ++++----
+ 1 file changed, 4 insertions(+), 4 deletions(-)
+
+diff --git a/gdk/win32/gdkdisplay-win32.c b/gdk/win32/gdkdisplay-win32.c
+index c2b572b402..0fa92a7143 100644
+--- a/gdk/win32/gdkdisplay-win32.c
++++ b/gdk/win32/gdkdisplay-win32.c
+@@ -916,10 +916,10 @@ _gdk_win32_enable_hidpi (GdkWin32Display *display)
+           /* then make the GDK-using app DPI-aware */
+           if (display->shcore_funcs.setDpiAwareFunc != NULL)
+             {
+-              switch (display->shcore_funcs.setDpiAwareFunc (PROCESS_SYSTEM_DPI_AWARE))
++              switch (display->shcore_funcs.setDpiAwareFunc (PROCESS_PER_MONITOR_DPI_AWARE))
+                 {
+                   case S_OK:
+-                    display->dpi_aware_type = PROCESS_SYSTEM_DPI_AWARE;
++                    display->dpi_aware_type = PROCESS_PER_MONITOR_DPI_AWARE;
+                     status = DPI_STATUS_SUCCESS;
+                     break;
+                   case E_ACCESSDENIED:
+@@ -1000,10 +1000,10 @@ _gdk_win32_enable_hidpi (GdkWin32Display *display)
+               /* This most probably means DPI awareness is set through
+                  the manifest, or a DPI compatibility setting is used. */
+               display->dpi_aware_type = display->user32_dpi_funcs.isDpiAwareFunc () ?
+-                                        PROCESS_SYSTEM_DPI_AWARE :
++                                        PROCESS_PER_MONITOR_DPI_AWARE :
+                                         PROCESS_DPI_UNAWARE;
+ 
+-              if (display->dpi_aware_type == PROCESS_SYSTEM_DPI_AWARE)
++              if (display->dpi_aware_type != PROCESS_DPI_UNAWARE)
+                 status = DPI_STATUS_SUCCESS;
+               else
+                 status = DPI_STATUS_DISABLED;
+-- 
+GitLab
+


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]