two small fixes for dzsave

fix a tiny leak, fix coloured @background
This commit is contained in:
John Cupitt 2015-10-06 13:30:25 +01:00
parent 8f4dfa5cb6
commit db291daf81
2 changed files with 20 additions and 19 deletions

View File

@ -406,7 +406,6 @@ struct _VipsForeignSaveDz {
int overlap; int overlap;
int tile_size; int tile_size;
VipsForeignDzLayout layout; VipsForeignDzLayout layout;
VipsArrayDouble *background;
VipsForeignDzDepth depth; VipsForeignDzDepth depth;
gboolean centre; gboolean centre;
gboolean properties; gboolean properties;
@ -688,28 +687,34 @@ write_properties( VipsForeignSaveDz *dz )
static int static int
write_blank( VipsForeignSaveDz *dz ) write_blank( VipsForeignSaveDz *dz )
{ {
VipsForeignSave *save = (VipsForeignSave *) dz;
VipsImage *x, *t; VipsImage *x, *t;
int n; int n;
VipsArea *ones; VipsArea *ones;
double *d; double *d;
double *bg;
int i; int i;
void *buf; void *buf;
size_t len; size_t len;
GsfOutput *out; GsfOutput *out;
if( vips_black( &x, dz->tile_size, dz->tile_size, NULL ) ) /* Number of bands we will end up making. We need to set this in
* vips_black() to make sure we set Type correctly, otherwise we can
* try saving a B_W image as PNG, with disasterous results.
*/
bg = (double *) vips_area_get_data( (VipsArea *) save->background,
NULL, &n, NULL, NULL );
if( vips_black( &x, dz->tile_size, dz->tile_size, "bands", n, NULL ) )
return( -1 ); return( -1 );
vips_area_get_data( (VipsArea *) dz->background, NULL, &n, NULL, NULL );
ones = vips_area_new_array( G_TYPE_DOUBLE, sizeof( double ), n ); ones = vips_area_new_array( G_TYPE_DOUBLE, sizeof( double ), n );
d = (double *) vips_area_get_data( ones, NULL, NULL, NULL, NULL ); d = (double *) vips_area_get_data( ones, NULL, NULL, NULL, NULL );
for( i = 0; i < n; i++ ) for( i = 0; i < n; i++ )
d[i] = 1.0; d[i] = 1.0;
if( vips_linear( x, &t,
d, if( vips_linear( x, &t, d, bg, n, NULL ) ) {
(double *) vips_area_get_data( (VipsArea *) dz->background,
NULL, NULL, NULL, NULL ),
n, NULL ) ) {
vips_area_unref( ones ); vips_area_unref( ones );
g_object_unref( x ); g_object_unref( x );
return( -1 ); return( -1 );
@ -1075,6 +1080,7 @@ strip_work( VipsThreadState *state, void *a )
Strip *strip = (Strip *) a; Strip *strip = (Strip *) a;
Layer *layer = strip->layer; Layer *layer = strip->layer;
VipsForeignSaveDz *dz = layer->dz; VipsForeignSaveDz *dz = layer->dz;
VipsForeignSave *save = (VipsForeignSave *) dz;
VipsObjectClass *class = VIPS_OBJECT_GET_CLASS( dz ); VipsObjectClass *class = VIPS_OBJECT_GET_CLASS( dz );
VipsImage *x; VipsImage *x;
@ -1125,7 +1131,7 @@ strip_work( VipsThreadState *state, void *a )
*/ */
if( dz->layout == VIPS_FOREIGN_DZ_LAYOUT_GOOGLE ) { if( dz->layout == VIPS_FOREIGN_DZ_LAYOUT_GOOGLE ) {
if( vips_embed( x, &t, 0, 0, dz->tile_size, dz->tile_size, if( vips_embed( x, &t, 0, 0, dz->tile_size, dz->tile_size,
"background", dz->background, "background", save->background,
NULL ) ) { NULL ) ) {
g_object_unref( x ); g_object_unref( x );
return( -1 ); return( -1 );
@ -1510,7 +1516,8 @@ vips_foreign_save_dz_build( VipsObject *object )
VIPS_SETSTR( dz->suffix, ".jpg" ); VIPS_SETSTR( dz->suffix, ".jpg" );
} }
/* Default to white background. /* Default to white background. vips_foreign_save_init() defaults to
* black.
*/ */
if( dz->layout == VIPS_FOREIGN_DZ_LAYOUT_GOOGLE && if( dz->layout == VIPS_FOREIGN_DZ_LAYOUT_GOOGLE &&
!vips_object_argument_isset( object, "background" ) ) { !vips_object_argument_isset( object, "background" ) ) {
@ -1594,7 +1601,7 @@ vips_foreign_save_dz_build( VipsObject *object )
if( vips_embed( save->ready, &z, if( vips_embed( save->ready, &z,
real_pixels.left, real_pixels.top, real_pixels.left, real_pixels.top,
size, size, size, size,
"background", dz->background, "background", save->background,
NULL ) ) NULL ) )
return( -1 ); return( -1 );
@ -1919,13 +1926,6 @@ vips_foreign_save_dz_class_init( VipsForeignSaveDzClass *class )
G_STRUCT_OFFSET( VipsForeignSaveDz, tile_size ), G_STRUCT_OFFSET( VipsForeignSaveDz, tile_size ),
1, 8192, 256 ); 1, 8192, 256 );
VIPS_ARG_BOXED( class, "background", 12,
_( "Background" ),
_( "Colour for background pixels" ),
VIPS_ARGUMENT_OPTIONAL_INPUT,
G_STRUCT_OFFSET( VipsForeignSaveDz, background ),
VIPS_TYPE_ARRAY_DOUBLE );
VIPS_ARG_ENUM( class, "depth", 13, VIPS_ARG_ENUM( class, "depth", 13,
_( "Depth" ), _( "Depth" ),
_( "Pyramid depth" ), _( "Pyramid depth" ),

View File

@ -371,7 +371,8 @@ class TestForeign(unittest.TestCase):
self.assertEqual(x.height, 256) self.assertEqual(x.height, 256)
y = Vips.Image.new_from_file("test_files/10/3_3.jpeg") y = Vips.Image.new_from_file("test_files/10/3_3.jpeg")
self.assertEqual(y.height, self.assertEqual(y.height,
self.colour.height - 255 * int(self.colour.height / 255)) self.colour.height -
255 * int(self.colour.height / 255))
# there should be a bottom layer # there should be a bottom layer
x = Vips.Image.new_from_file("test_files/0/0_0.jpeg") x = Vips.Image.new_from_file("test_files/0/0_0.jpeg")