emacs-diffs
[Top][All Lists]
Advanced

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

[Emacs-diffs] emacs-26 1d743d2: Fix scaling problem in Cairo builds


From: Eli Zaretskii
Subject: [Emacs-diffs] emacs-26 1d743d2: Fix scaling problem in Cairo builds
Date: Sat, 8 Dec 2018 04:51:06 -0500 (EST)

branch: emacs-26
commit 1d743d2461a5a90893a0cbe62239f31b321a844d
Author: Ari Roponen <address@hidden>
Commit: Eli Zaretskii <address@hidden>

    Fix scaling problem in Cairo builds
    
    * src/xterm.c (x_begin_cr_clip) [USE_GTK]:
    (x_update_begin) [USE_CAIRO && USE_GTK]: Support scaling.
    (Bug#33442)
---
 src/xterm.c | 14 ++++++++++----
 1 file changed, 10 insertions(+), 4 deletions(-)

diff --git a/src/xterm.c b/src/xterm.c
index b2d1b5c..8157612 100644
--- a/src/xterm.c
+++ b/src/xterm.c
@@ -360,10 +360,15 @@ x_begin_cr_clip (struct frame *f, GC gc)
 
       if (! FRAME_CR_SURFACE (f))
         {
+         int scale = 1;
+#ifdef USE_GTK
+         scale = xg_get_scale (f);
+#endif
+
          FRAME_CR_SURFACE (f) =
            cairo_image_surface_create (CAIRO_FORMAT_ARGB32,
-                                       FRAME_PIXEL_WIDTH (f),
-                                       FRAME_PIXEL_HEIGHT (f));
+                                       scale * FRAME_PIXEL_WIDTH (f),
+                                       scale * FRAME_PIXEL_HEIGHT (f));
        }
       cr = cairo_create (FRAME_CR_SURFACE (f));
       FRAME_CR_CONTEXT (f) = cr;
@@ -1006,8 +1011,9 @@ x_update_begin (struct frame *f)
       if (FRAME_GTK_WIDGET (f))
         {
           GdkWindow *w = gtk_widget_get_window (FRAME_GTK_WIDGET (f));
-          width = gdk_window_get_width (w);
-          height = gdk_window_get_height (w);
+         int scale = xg_get_scale (f);
+         width = scale * gdk_window_get_width (w);
+          height = scale * gdk_window_get_height (w);
         }
       else
 #endif



reply via email to

[Prev in Thread] Current Thread [Next in Thread]