all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Alan Third <alan@idiocy.org>
To: Lars Ingebrigtsen <larsi@gnus.org>
Cc: 38394@debbugs.gnu.org
Subject: bug#38394: Fwd: Use different image filtering when zooming in vs zooming out
Date: Sun, 2 Aug 2020 21:35:15 +0100	[thread overview]
Message-ID: <20200802203515.GA70565@breton.holly.idiocy.org> (raw)
In-Reply-To: <87o8ntey06.fsf@gnus.org>

[-- Attachment #1: Type: text/plain, Size: 1013 bytes --]

On Sun, Aug 02, 2020 at 07:52:25PM +0200, Lars Ingebrigtsen wrote:
> Alan Third <alan@idiocy.org> writes:
> 
> > It might be worth smoothing on scaling down, but not on scaling up.
> > That way if you zoom in you get exact pixels, but zooming out you
> > don’t get aliasing effects.
> >
> > I don’t know if that would add any other problems...
> 
> You apparently didn't apply this patch?

There didn't appear to be much enthusiasm so I just left it in case
someone requested it in the future.

> > * src/image.c (image_set_transform [HAVE_XRENDER]): Use different filter
> > when zooming in vs zooming out.
> 
> I think it makes sense...  although I'm not sure of what the effects are
> if you just increase the image size by, say, a couple percent.

I've attached an updated version of this patch and a screenshot
showing the result with a couple of levels of scaling.

Annoyingly we now use Cairo by default which is unaffected by this
change, so only plain X users will see this behaviour.
-- 
Alan Third

[-- Attachment #2: scaling.png --]
[-- Type: image/png, Size: 25663 bytes --]

[-- Attachment #3: 0001-Don-t-smooth-images-when-scaling-up-bug-38394.patch --]
[-- Type: text/plain, Size: 2026 bytes --]

From bdd090bf8cc29bd5427d69f10bf0738a74596ba7 Mon Sep 17 00:00:00 2001
From: Alan Third <alan@idiocy.org>
Date: Sun, 2 Aug 2020 20:43:56 +0100
Subject: [PATCH] Don't smooth images when scaling up (bug#38394)

* src/image.c (image_set_transform [HAVE_XRENDER]): Use different filter
when scaling up vs scaling down.
---
 src/image.c | 15 ++++++++++++---
 1 file changed, 12 insertions(+), 3 deletions(-)

diff --git a/src/image.c b/src/image.c
index e7e0a93313..ce4c34df7b 100644
--- a/src/image.c
+++ b/src/image.c
@@ -2114,6 +2114,15 @@ image_set_transform (struct frame *f, struct image *img)
   double rotation = 0.0;
   compute_image_rotation (img, &rotation);
 
+# if !defined USE_CAIRO && defined HAVE_XRENDER
+  /* We want scale up operations to use a nearest neighbour filter to
+     show real pixels instead of munging them, but scale down
+     operations to use a blended filter, to avoid aliasing and the like.
+
+     TODO: implement for Cairo, NS and Windows.  */
+  bool scale_down = (width < img->width) || (height < img->height);
+# endif
+
   /* Perform scale transformation.  */
 
   matrix3x3 matrix
@@ -2246,14 +2255,14 @@ image_set_transform (struct frame *f, struct image *img)
              XDoubleToFixed (matrix[1][2]),
              XDoubleToFixed (matrix[2][2])}}};
 
-      XRenderSetPictureFilter (FRAME_X_DISPLAY (f), img->picture, FilterBest,
-			       0, 0);
+      XRenderSetPictureFilter (FRAME_X_DISPLAY (f), img->picture,
+                               scale_down ? FilterBest : FilterNearest, 0, 0);
       XRenderSetPictureTransform (FRAME_X_DISPLAY (f), img->picture, &tmat);
 
       if (img->mask_picture)
         {
           XRenderSetPictureFilter (FRAME_X_DISPLAY (f), img->mask_picture,
-                                   FilterBest, 0, 0);
+                                   scale_down ? FilterBest : FilterNearest, 0, 0);
           XRenderSetPictureTransform (FRAME_X_DISPLAY (f), img->mask_picture,
                                       &tmat);
         }
-- 
2.26.1


  reply	other threads:[~2020-08-02 20:35 UTC|newest]

Thread overview: 67+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-11-07 21:11 bug#38109: 27.0.50; xpm image scaling doesn't work Unknown
2019-11-07 21:30 ` bug#38109: Updated Emacs to HEAD, consistently not scaling now Unknown
2019-11-07 21:49   ` Lars Ingebrigtsen
2019-11-07 21:54     ` Unknown
2019-11-07 22:03       ` Lars Ingebrigtsen
2019-11-07 22:12         ` Unknown
2019-11-08 19:34           ` Alan Third
2019-11-08 19:38             ` Alan Third
2019-11-08 21:19               ` Unknown
2019-11-08 21:03             ` Unknown
2019-11-08 21:12               ` Lars Ingebrigtsen
2019-11-08 21:18                 ` Unknown
2019-11-08 21:19                   ` Lars Ingebrigtsen
2019-11-08 21:35                     ` Unknown
2019-11-08 23:03               ` Alan Third
2019-11-09 17:22                 ` Alan Third
2019-11-09 17:58                   ` Eli Zaretskii
2019-11-09 18:11                     ` Alan Third
2019-11-09 18:42                       ` Eli Zaretskii
2019-11-09 20:09                   ` Lars Ingebrigtsen
2019-11-09 21:56                   ` Unknown
2019-11-09 22:18                     ` Unknown
2019-11-09 23:13                       ` Unknown
2019-11-10 17:12                         ` Alan Third
2019-11-16 16:53                           ` Unknown
2019-11-17 17:22                             ` Alan Third
2019-11-17 18:23                               ` Unknown
2019-11-17 18:49                                 ` Unknown
2019-11-17 19:01                                   ` Alan Third
2019-11-09  6:33               ` Eli Zaretskii
2019-11-09 10:28                 ` Unknown
2019-11-09 10:37                   ` Eli Zaretskii
2019-11-08 21:11             ` Lars Ingebrigtsen
2019-11-08 23:06               ` Alan Third
2019-11-08  6:36     ` Eli Zaretskii
2019-11-08 21:04       ` Lars Ingebrigtsen
2019-11-09  6:31         ` Eli Zaretskii
2019-11-07 21:58 ` bug#38109: 27.0.50; xpm image scaling doesn't work Stephen Berman
2019-11-08  6:28 ` Eli Zaretskii
2019-11-08  8:17   ` Unknown
2019-11-08 21:46 ` bug#38109: Another data point Unknown
2019-11-08 22:02   ` Lars Ingebrigtsen
2019-11-23  0:02 ` bug#38109: Updated Emacs to HEAD, consistently not scaling now Unknown
2019-11-24 17:26   ` Alan Third
2019-11-24 17:52     ` Unknown
2019-11-26 20:36       ` Alan Third
2019-11-26 20:40         ` Unknown
     [not found]           ` <20191126212729.GC7891@breton.holly.idiocy.org>
2019-11-26 21:39             ` bug#38394: Fwd: Use different image filtering when zooming in vs zooming out Alan Third
2019-11-27 12:32               ` Lars Ingebrigtsen
2019-12-02 13:05                 ` Alan Third
2019-12-05 10:02                   ` Lars Ingebrigtsen
2020-08-02 17:52               ` Lars Ingebrigtsen
2020-08-02 20:35                 ` Alan Third [this message]
2020-08-03  6:10                   ` Lars Ingebrigtsen
2020-08-03  9:10                     ` Alan Third
2020-08-03 14:04                       ` Robert Pluim
2020-08-03 15:13                         ` Alan Third
2020-08-03 19:55                           ` Robert Pluim
2020-08-04  8:52                       ` Lars Ingebrigtsen
2020-08-04 19:51                         ` Alan Third
2020-08-05  8:47                           ` Lars Ingebrigtsen
2020-08-14  6:03               ` David Ponce
2020-08-14 20:20                 ` Alan Third
2020-08-14 21:14                   ` David Ponce
2020-08-14 23:10                     ` Alan Third
2020-08-15  7:04                       ` David Ponce
2019-11-29 21:27     ` bug#38109: Updated Emacs to HEAD, consistently not scaling now Alan Third

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20200802203515.GA70565@breton.holly.idiocy.org \
    --to=alan@idiocy.org \
    --cc=38394@debbugs.gnu.org \
    --cc=larsi@gnus.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this external index

	https://git.savannah.gnu.org/cgit/emacs.git
	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.