4

我正在使用 vaadin-charts:3.2.0 可视化一些数据,并且我正在尝试从图表中导出 SVG。我得到了一些结果,但并不令人满意。我只能共享屏幕主机而不是 SVG 本身。我还必须对标签进行像素化以掩盖私人数据。

在屏幕上看到的原始 vaadin 图表: 在屏幕上看到的原始 vaadin 图表

导出的 SVG: 导出的 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;
}
4

0 回答 0