Java将svg转化成png,将SVG转换为PNG图像

i am converting angular nvd3 chart to svg using html2canvas and canvg plugings but when i convert pie chart to png then i looks same as chart but when i convert line chart or area chart then its background goes to black and some circle drown on image.

My code is

var svgElements = $("#container").find('svg');

//replace all svgs with a temp canvas

svgElements.each(function () {

var canvas, xml;

// canvg doesn't cope very well with em font sizes so find the calculated size in pixels and replace it in the element.

$.each($(this).find('[style*=em]'), function (index, el) {

$(this).css('font-size', getStyle(el, 'font-size'));

});

canvas = document.createElement("canvas");

canvas.className = "screenShotTempCanvas";

/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 后台可以使用 Apache Batik 库将 SVG 转换PNG。Apache Batik 是一个开源的 Java 库,提供了许多用于处理 SVG 的 API。 以下是一个简单的 Java 代码示例,用于将 SVG 文件转换PNG 文件: ```java import java.io.*; import org.apache.batik.transcoder.image.PNGTranscoder; import org.apache.batik.transcoder.TranscoderInput; import org.apache.batik.transcoder.TranscoderOutput; public class SvgToPngConverter { public static void main(String[] args) { try { // 创建码器 PNGTranscoder transcoder = new PNGTranscoder(); // 设置输入输出 String svgFileName = "input.svg"; String pngFileName = "output.png"; TranscoderInput input = new TranscoderInput(new FileInputStream(svgFileName)); TranscoderOutput output = new TranscoderOutput(new FileOutputStream(pngFileName)); // 开始转换 transcoder.transcode(input, output); // 关闭流 input.getInputStream().close(); output.getOutputStream().close(); System.out.println("SVG 文件转换PNG 文件成功!"); } catch (Exception e) { System.err.println("SVG 文件转换PNG 文件失败:" + e.getMessage()); } } } ``` 在上面的代码中,我们首先创建了一个 `PNGTranscoder` 对象,然后指定输入和输出文件名,最后调用 `transcode` 方法进行转换。 请注意,该代码需要引入 Apache Batik 库,可以在 Maven 中添加以下依赖项: ```xml <dependency> <groupId>org.apache.xmlgraphics</groupId> <artifactId>batik-transcoder</artifactId> <version>1.14</version> </dependency> ``` 希望对你有帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值