我正在使用 vaadin-charts:3.2.0 可视化一些数据,并且我正在尝试从图表中导出 SVG。我得到了一些结果,但并不令人满意。我只能共享屏幕主机而不是 SVG 本身。我还必须对标签进行像素化以掩盖私人数据。
在屏幕上看到的原始 vaadin 图表:
导出的 SVG:
一个问题是标签溢出了 svg 边界。并且图表图纸也超出了边界,使其看起来像是一张不完整的图纸。知道这个结构有什么问题吗?
public class SvgStreamResource extends StreamResource {
public SvgStreamResource(String svgText, String filename) {
super(new StreamSource() {
@Override
public InputStream getStream() {
InputStream s = new BufferedInputStream( new ReaderInputStream(new StringReader(svgText)));
return s;
}
}, filename + ".svg");
}
@Override
public String getMIMEType() {
return "image/svg+xml";
}
}
在一个组件内:
Button exportButton = createExportButton("SVG", createSVGStreamSource(conf));
private SvgStreamResource createSVGStreamSource(Configuration conf) {
String svg = SVGGenerator.getInstance().generate(conf);
return new SvgStreamResource(svg, fileBaseName);
}
private Button createExportButton(String caption, SvgStreamResource svgStreamResource) {
Button b = new Button(caption);
FileDownloader downloader = new FileDownloader(svgStreamResource);
downloader.extend(b);
return b;
}