don't output transparency ifrom openslide

openslide now always outputs solid colours, helps vips_flatten() convert
to RGB for jpg tile save correctly
This commit is contained in:
John Cupitt 2013-08-06 12:58:07 +01:00
parent ba60202285
commit 497cf55fc0
2 changed files with 15 additions and 3 deletions

View File

@ -37,6 +37,8 @@
* 11/10/12 * 11/10/12
* - look for tile-width and tile-height properties * - look for tile-width and tile-height properties
* - use threaded tile cache * - use threaded tile cache
* 6/8/13
* - always output solid (not transparent) pixels
*/ */
/* /*
@ -259,6 +261,7 @@ readslide_new( const char *filename, VipsImage *out,
return( NULL ); return( NULL );
} }
vips_image_init_fields( out, w, h, 4, VIPS_FORMAT_UCHAR, vips_image_init_fields( out, w, h, 4, VIPS_FORMAT_UCHAR,
VIPS_CODING_NONE, VIPS_INTERPRETATION_RGB, 1.0, 1.0 ); VIPS_CODING_NONE, VIPS_INTERPRETATION_RGB, 1.0, 1.0 );
@ -331,6 +334,15 @@ vips__openslide_generate( VipsRegion *out,
/* Convert from ARGB to RGBA and undo premultiplication. Since we are /* Convert from ARGB to RGBA and undo premultiplication. Since we are
* inside a cache, we know buf must be continuous. * inside a cache, we know buf must be continuous.
*
* We throw away transparency. Formats like Mirax use transparent + bg
* colour for areas with no useful pixels. But if we output
* transparent pixels and then convert to RGB for jpeg write later, we
* would have to pass the bg colour down the pipe somehow. The
* structure of dzsave makes this tricky.
*
* We could output plain RGB instead, but that would break
* compatibility with older vipses.
*/ */
for( i = 0; i < n; i++ ) { for( i = 0; i < n; i++ ) {
uint32_t *p = buf + i; uint32_t *p = buf + i;
@ -342,7 +354,7 @@ vips__openslide_generate( VipsRegion *out,
out[0] = 255 * ((x >> 16) & 255) / a; out[0] = 255 * ((x >> 16) & 255) / a;
out[1] = 255 * ((x >> 8) & 255) / a; out[1] = 255 * ((x >> 8) & 255) / a;
out[2] = 255 * (x & 255) / a; out[2] = 255 * (x & 255) / a;
out[3] = a; out[3] = 255;
} }
else { else {
/* Use background color. /* Use background color.
@ -350,7 +362,7 @@ vips__openslide_generate( VipsRegion *out,
out[0] = (bg >> 16) & 255; out[0] = (bg >> 16) & 255;
out[1] = (bg >> 8) & 255; out[1] = (bg >> 8) & 255;
out[2] = bg & 255; out[2] = bg & 255;
out[3] = 0; out[3] = 255;
} }
} }

View File

@ -37,9 +37,9 @@
*/ */
/* /*
*/
#define VIPS_DEBUG #define VIPS_DEBUG
#define DEBUG #define DEBUG
*/
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include <config.h> #include <config.h>