summaryrefslogtreecommitdiff
path: root/draw/imagedraw.c
diff options
context:
space:
mode:
Diffstat (limited to 'draw/imagedraw.c')
-rw-r--r--draw/imagedraw.c20
1 files changed, 13 insertions, 7 deletions
diff --git a/draw/imagedraw.c b/draw/imagedraw.c
index c44a3ba1..044b2938 100644
--- a/draw/imagedraw.c
+++ b/draw/imagedraw.c
@@ -289,14 +289,20 @@ fz_paintimageimp(fz_pixmap *dst, fz_bbox scissor, fz_pixmap *img, fz_matrix ctm,
/* turn on interpolation for upscaled and non-rectilinear transforms */
dolerp = 0;
- if (img->interpolate)
+ if (!fz_isrectilinear(ctm))
+ dolerp = 1;
+ if (sqrtf(ctm.a * ctm.a + ctm.b * ctm.b) > img->w)
+ dolerp = 1;
+ if (sqrtf(ctm.c * ctm.c + ctm.d * ctm.d) > img->h)
+ dolerp = 1;
+
+ /* except when we shouldn't, at large magnifications */
+ if (!img->interpolate)
{
- if (!fz_isrectilinear(ctm))
- dolerp = 1;
- if (sqrtf(ctm.a * ctm.a + ctm.b * ctm.b) > img->w)
- dolerp = 1;
- if (sqrtf(ctm.c * ctm.c + ctm.d * ctm.d) > img->h)
- dolerp = 1;
+ if (sqrtf(ctm.a * ctm.a + ctm.b * ctm.b) > img->w * 2)
+ dolerp = 0;
+ if (sqrtf(ctm.c * ctm.c + ctm.d * ctm.d) > img->h * 2)
+ dolerp = 0;
}
bbox = fz_roundrect(fz_transformrect(ctm, fz_unitrect));