From 060bdd2cf0c545291908017cf738736a15f7fa4e Mon Sep 17 00:00:00 2001 From: John Cupitt Date: Sat, 8 Jul 2017 16:03:56 +0100 Subject: [PATCH] fix svgload resolution again use rsvg_handle_set_dpi() rather than cairo_scale() to avoid int truncation on dimensions see https://github.com/jcupitt/libvips/issues/688 --- libvips/foreign/svgload.c | 32 +++++--------------------------- test/images/blankpage.svg.png | Bin 3389 -> 3409 bytes 2 files changed, 5 insertions(+), 27 deletions(-) diff --git a/libvips/foreign/svgload.c b/libvips/foreign/svgload.c index b2306d2c..9c425506 100644 --- a/libvips/foreign/svgload.c +++ b/libvips/foreign/svgload.c @@ -109,26 +109,6 @@ vips_foreign_load_svg_dispose( GObject *gobject ) dispose( gobject ); } -static int -vips_foreign_load_svg_build( VipsObject *object ) -{ - VipsForeignLoadSvg *svg = (VipsForeignLoadSvg *) object; - - if( !vips_object_argument_isset( object, "scale" ) ) - svg->scale = svg->dpi / 72.0; - - /* librsvg defaults to 90 DPI, but vips defaults to 72. We need to - * adjust the scale down. - */ - svg->scale *= 72.0 / 90.0; - - if( VIPS_OBJECT_CLASS( vips_foreign_load_svg_parent_class )-> - build( object ) ) - return( -1 ); - - return( 0 ); -} - static VipsForeignFlags vips_foreign_load_svg_get_flags_filename( const char *filename ) { @@ -150,6 +130,7 @@ vips_foreign_load_svg_parse( VipsForeignLoadSvg *svg, RsvgDimensionData dimensions; double res; + rsvg_handle_set_dpi( svg->page, svg->dpi * svg->scale ); rsvg_handle_get_dimensions( svg->page, &dimensions ); /* We need pixels/mm for vips. @@ -157,7 +138,7 @@ vips_foreign_load_svg_parse( VipsForeignLoadSvg *svg, res = svg->dpi / 25.4; vips_image_init_fields( out, - dimensions.width * svg->scale, dimensions.height * svg->scale, + dimensions.width, dimensions.height, 4, VIPS_FORMAT_UCHAR, VIPS_CODING_NONE, VIPS_INTERPRETATION_sRGB, res, res ); @@ -201,9 +182,7 @@ vips_foreign_load_svg_generate( VipsRegion *or, cr = cairo_create( surface ); cairo_surface_destroy( surface ); - cairo_scale( cr, svg->scale, svg->scale ); - cairo_translate( cr, - -r->left / svg->scale, -r->top / svg->scale ); + cairo_translate( cr, -r->left, -r->top ); /* rsvg is single-threaded, but we don't need to lock since we're * running inside a non-threaded tilecache. @@ -279,7 +258,6 @@ vips_foreign_load_svg_class_init( VipsForeignLoadSvgClass *class ) object_class->nickname = "svgload"; object_class->description = _( "load SVG with rsvg" ); - object_class->build = vips_foreign_load_svg_build; load_class->get_flags_filename = vips_foreign_load_svg_get_flags_filename; @@ -564,8 +542,8 @@ vips_foreign_load_svg_buffer_init( VipsForeignLoadSvgBuffer *buffer ) * Render a SVG file into a VIPS image. Rendering uses the librsvg library * and should be fast. * - * Use @dpi to set the rendering resolution. The default is 72. Alternatively, - * you can scale the rendering from the default 1 point == 1 pixel by @scale. + * Use @dpi to set the rendering resolution. The default is 72. You can also + * scale the rendering by @scale. * * This function only reads the image header and does not render any pixel * data. Rendering occurs when pixels are accessed. diff --git a/test/images/blankpage.svg.png b/test/images/blankpage.svg.png index b206d02753bf779126098457a33b88015b0fbb38..01e4e7393db1bcbdb9aa41d7387d5b7d050bfd7d 100644 GIT binary patch delta 162 zcmV;T0A2sR8qpe%7Ya%U1^@s6uJ6kaks%i+4FgF;K~#90?bg9b15f}3!IzMu2aB`g z6y#AsBo?udk71^QJ?;jvVc-Fga0D#dc6&S?pWD7qhXBA6T({jXm&?cL5MIY^+xzJV z0C=Le(*eAe>*)Xhfd9<15d;?rvrq%10Vi(TzPA0G4gr8CxNiGB9l>k)12576zyV(iMKrAPWy#k`^KW0000