0

This is a follow-up to How can I embed an SVG image using JSF/OmniFaces/PrimeFaces?

In that question, I learned that the OmniFaces-2.1 snapshot supports utilizing InputStream/byte[] through it's o:graphicImage tag.

In Getting started with SVG graphics objects in JSF 2.0 pages I learned that the standard graphicImage tags simply renders an img tag and SVG's should be rendered as and object tag like this: <object type="image/svg+xml" data="#{bean.svgUrl}">.

My question is really directed directly at BalusC from the OmniFaces project:

Should not o:graphicImage render SVG's in this manner? All I'm getting is img-tags and they don't work in IE10+.

Update #2: It's a scaling problem! I set the height to 125 and started seeing the edge my graphic.

UPDATE #1: Example rendered img tags:

This one is just based on a static SVG file: <img height="25" alt="" src="/javax.faces.resource/images/Logo.svg.xhtml;jsessionid=cc0acf6def65ac5c127d09384977?ln=default">

This is based on a byte array: <img src="" alt="100.1 - Farlig sving" title="100.1 - Farlig sving" width="40" style="margin-left: 3px; pointer-events: none;" height="40">

Community
  • 1
  • 1
matsa
  • 346
  • 5
  • 16
  • That question was from 2010. As per http://caniuse.com/#feat=svg-img IE9+ should support it. IE9 was introduced half 2011. How exactly does it fail? – BalusC Feb 18 '15 at 12:13
  • I've updated with a couple of examples. These render fine in FF and Chrome, but are simply invisible in IE. – matsa Feb 18 '15 at 12:58
  • 1
    As per your update, aha, scaling problem indeed. Check http://stackoverflow.com/questions/9777143/svg-in-img-element-proportions-not-respected-in-ie9, http://www.seowarp.com/blog/2011/06/svg-scaling-problems-in-ie9-and-other-browsers/, https://gist.github.com/larrybotha/7881691, etc – BalusC Feb 19 '15 at 13:35

1 Answers1

2

Since I discovered this to be a SVG scaling problem and I seem not to be the only one who has encountered this I'll post my solution here.

In short, I

  • Retrieve the SVG.
  • Parse it using JDOM.
  • Inject a view box if it is missing based on the specified size

Here's the Java code without error handling:

    ByteArrayOutputStream baos = new ByteArrayOutputStream();
    InputStream is = execute(builder.buildGet(), InputStream.class);
    Document doc = new SAXBuilder().build(is);
    Element root = doc.getRootElement();
    if (root.getAttribute("viewBox") == null)
    {
            String width = root.getAttributeValue("width"), height =  root.getAttributeValue("height");
            root.setAttribute("viewBox", String.format("0 0 %s %s", width, height));
    }

    new XMLOutputter().output(doc, baos);
    return baos.toByteArray();
matsa
  • 346
  • 5
  • 16