From 6cf7c89236d6b222f53ca9c8d681d6cde656bea1 Mon Sep 17 00:00:00 2001 From: Aaron Suen Date: Mon, 23 Mar 2015 02:23:29 -0400 Subject: Fix for sun/moon tonemaps: don't upscale 1px images. --- src/client/tile.cpp | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) (limited to 'src/client/tile.cpp') diff --git a/src/client/tile.cpp b/src/client/tile.cpp index 7b326c152..1cf9f1506 100644 --- a/src/client/tile.cpp +++ b/src/client/tile.cpp @@ -192,13 +192,18 @@ video::IImage *textureMinSizeUpscale(video::IVideoDriver *driver, video::IImage if(orig == NULL) return orig; s32 scaleto = g_settings->getS32("texture_min_size"); - if (scaleto > 0) { + if (scaleto > 1) { + const core::dimension2d dim = orig->getDimension(); + + // Don't upscale 1px images. They don't benefit from it anyway + // (wouldn't have been blurred) and MIGHT be sun/moon tonemaps. + if ((dim.Width <= 1) || (dim.Height <= 1)) + return orig; /* Calculate scaling needed to make the shortest texture dimension * equal to the target minimum. If e.g. this is a vertical frames * animation, the short dimension will be the real size. */ - const core::dimension2d dim = orig->getDimension(); u32 xscale = scaleto / dim.Width; u32 yscale = scaleto / dim.Height; u32 scale = (xscale > yscale) ? xscale : yscale; -- cgit v1.2.3