这是How can I embed an SVG image using JSF/OmniFaces/PrimeFaces?
的后续行动在那个问题中,我了解到OmniFaces-2.1快照支持通过它的o:graphicImage标签来使用InputStream / byte []。
在Getting started with SVG graphics objects in JSF 2.0 pages中,我了解到标准的graphicImage标记只是呈现 img 标记,而SVG应该呈现为和 object 标记一样:<object type="image/svg+xml" data="#{bean.svgUrl}">
。
我的问题实际上是直接针对来自OmniFaces项目的BalusC:
不应该o:graphicImage以这种方式呈现SVG吗?我得到的只是img-tags而且他们不能在IE10 +中工作。
更新#2:这是一个扩展问题!我将高度设置为125并开始看到我的图形边缘。
更新#1:示例呈现的img标签:
这个基于静态SVG文件:<img height="25" alt="" src="/javax.faces.resource/images/Logo.svg.xhtml;jsessionid=cc0acf6def65ac5c127d09384977?ln=default">
这基于一个字节数组:
<img src="" alt="100.1 - Farlig sving" title="100.1 - Farlig sving" width="40" style="margin-left: 3px; pointer-events: none;" height="40">
答案 0 :(得分:0)
由于我发现这是一个SVG扩展问题,而且我似乎不是唯一一个遇到过这个问题的人,我会在这里发布我的解决方案。
简而言之,我
这里是没有错误处理的Java代码:
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();