From 17bf613fe48290ed49c1097534e71cacab3ff5eb Mon Sep 17 00:00:00 2001 From: Jeremias Maerki Date: Tue, 6 Sep 2005 10:18:58 +0000 Subject: [PATCH] Bugzilla #36505: Several fixes for SVG painting in the Java2DRenderer. Updated SVG test case to test additional features. Submitted by: Richard Wheeldon Comments and changes by jeremias: Added an additional SVG image with an intrinsic size and modified the test case to use and test that, too. I'll commit this patch because it improves the current situation but I'm not happy with the current state of Java2DRenderer.renderSVGDocument(). Creating inverse transformation matrices is surely not the right way to do this. The matrix should be saved and restored instead. Furthermore, renderSVGDocument should be extracted into a Java2DSVGHandler like it is done for the other renderers. git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@278966 13f79535-47bb-0310-9956-ffa450edef68 --- .../fop/render/java2d/Java2DRenderer.java | 20 +-- .../testcases/external-graphic_svg.xml | 129 +++++++++++------- test/resources/images/img-w-size.svg | 25 ++++ 3 files changed, 117 insertions(+), 57 deletions(-) create mode 100644 test/resources/images/img-w-size.svg diff --git a/src/java/org/apache/fop/render/java2d/Java2DRenderer.java b/src/java/org/apache/fop/render/java2d/Java2DRenderer.java index b807d8ced..56c30ac7f 100644 --- a/src/java/org/apache/fop/render/java2d/Java2DRenderer.java +++ b/src/java/org/apache/fop/render/java2d/Java2DRenderer.java @@ -48,7 +48,6 @@ import java.util.Map; import org.apache.batik.bridge.BridgeContext; import org.apache.batik.bridge.GVTBuilder; -import org.apache.batik.bridge.ViewBox; import org.apache.batik.dom.svg.SVGDOMImplementation; import org.apache.batik.gvt.GraphicsNode; import org.apache.fop.apps.FOPException; @@ -1096,15 +1095,21 @@ public abstract class Java2DRenderer extends AbstractRenderer implements Printab "svg graphic could not be built: " + e.getMessage(), e); return; } - float w = (float) ctx.getDocumentSize().getWidth() * 1000f; - float h = (float) ctx.getDocumentSize().getHeight() * 1000f; + + // If no viewbox is defined in the svg file, a viewbox of 100x100 is + // assumed, as defined in SVGUserAgent.getViewportSize() + float iw = (float) ctx.getDocumentSize().getWidth() * 1000f; + float ih = (float) ctx.getDocumentSize().getHeight() * 1000f; + + float w = (float) pos.getWidth(); + float h = (float) pos.getHeight(); // correct integer roundoff state.getGraph().translate(x / 1000, y / 1000); SVGSVGElement svg = ((SVGDocument) doc).getRootElement(); - AffineTransform at = ViewBox.getPreserveAspectRatioTransform(svg, - w / 1000f, h / 1000f); + // Aspect ratio preserved by layout engine, not here + AffineTransform at = AffineTransform.getScaleInstance(w / iw, h / ih); AffineTransform inverse = null; try { inverse = at.createInverse(); @@ -1125,10 +1130,7 @@ public abstract class Java2DRenderer extends AbstractRenderer implements Printab state.getGraph().transform(inverse); } // correct integer roundoff - // currentState.getCurrentGraphics().translate(-x / 1000f, y / 1000f - - // pageHeight); - state.getGraph().translate(-(x + 500) / 1000, - (y + 500) / 1000 - pageHeight); + state.getGraph().translate(-(x + 500) / 1000, -(y + 500) / 1000); } /** diff --git a/test/layoutengine/testcases/external-graphic_svg.xml b/test/layoutengine/testcases/external-graphic_svg.xml index c51cb0e4d..5f13dc313 100644 --- a/test/layoutengine/testcases/external-graphic_svg.xml +++ b/test/layoutengine/testcases/external-graphic_svg.xml @@ -1,48 +1,81 @@ - - - - - -

- This test checks external-graphics. -

-
- - - - - - - - - - SVG external-graphic - - EOG - - EOF - - - - - - - - - - -
+ + + + + +

+ This test checks external-graphics. +

+
+ + + + + + + + + + 2 inch wide SVG external-graphic on LHS + + EOG + + 4 inch wide SVG external-graphic on RHS + + EOG + + 6 inch wide SVG external-graphic in center, non-uniformly squeezed to a height of 4in. + + EOG + + SVG external-graphic with an intrinsic size (16ptx16pt) + + EOG + + EOF + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
diff --git a/test/resources/images/img-w-size.svg b/test/resources/images/img-w-size.svg new file mode 100644 index 000000000..503490b79 --- /dev/null +++ b/test/resources/images/img-w-size.svg @@ -0,0 +1,25 @@ + + + + + + + + + + + -- 2.39.5