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
next prev parent 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.