From f1d901a229bc0f3738335cdedd3c051016eebf23 Mon Sep 17 00:00:00 2001 From: John Cupitt Date: Mon, 19 Jan 2015 14:52:57 +0000 Subject: [PATCH] try to handle tiffs with 8-bit colormaps see https://github.com/jcupitt/libvips/issues/220 --- ChangeLog | 1 + libvips/foreign/tiff2vips.c | 31 +++++++++++++++++++++++++++---- 2 files changed, 28 insertions(+), 4 deletions(-) diff --git a/ChangeLog b/ChangeLog index 3dcb60ba..88d1f36b 100644 --- a/ChangeLog +++ b/ChangeLog @@ -9,6 +9,7 @@ - renamed VIPS_FOREIGN_DZ_DEPTH_1 as VIPS_FOREIGN_DZ_DEPTH_ONE etc. to help bindings - vipsthumbnail will return an error code if one or more conversions failed +- try to handle tiffs with old-style 8-bit colormaps 24/12/14 started 7.42.1 - add gobject-2.0 to Requires: in vips and vips-cpp .pc files diff --git a/libvips/foreign/tiff2vips.c b/libvips/foreign/tiff2vips.c index 1bfe73e0..a36d9dc8 100644 --- a/libvips/foreign/tiff2vips.c +++ b/libvips/foreign/tiff2vips.c @@ -152,6 +152,8 @@ * - better istiff detector spots bigtiff * 3/12/14 * - read any XMP metadata + * 19/1/15 + * - try to handle 8-bit colormaps */ /* @@ -853,10 +855,31 @@ parse_palette( ReadTiff *rtiff, VipsImage *out ) vips_error( "tiff2vips", "%s", _( "bad colormap" ) ); return( -1 ); } - for( i = 0; i < len; i++ ) { - read->red8[i] = read->red16[i] >> 8; - read->green8[i] = read->green16[i] >> 8; - read->blue8[i] = read->blue16[i] >> 8; + + /* Old-style colourmaps were 8-bit. If all the top bytes are zero, + * assume we have one of these. + * + * See: https://github.com/jcupitt/libvips/issues/220 + */ + for( i = 0; i < len; i++ ) + if( (read->red16[i] >> 8) | + (read->green16[i] >> 8) | + (read->blue16[i] >> 8) ) + break; + if( i < len ) + for( i = 0; i < len; i++ ) { + read->red8[i] = read->red16[i] >> 8; + read->green8[i] = read->green16[i] >> 8; + read->blue8[i] = read->blue16[i] >> 8; + } + else { + vips_warn( "tiff2vips", "%s", _( "assuming 8-bit palette" ) ); + + for( i = 0; i < len; i++ ) { + read->red8[i] = read->red16[i] & 0xff; + read->green8[i] = read->green16[i] & 0xff; + read->blue8[i] = read->blue16[i] & 0xff; + } } /* Are all the maps equal? We have a mono image.