java base64 svg转png_javascript – 使用非常大的SVG转换为PNG

Working fiddle.

HTML:

width="526" height="233">

fill="none" stroke="blue" stroke-width="10" />

Save

JavaScript的:

var svg = document.getElementsByTagName('svg')[0];

var svg_xml = (new XMLSerializer()).serializeToString(svg),

blob = new Blob([svg_xml], {type:'image/svg+xml;charset=utf-8'}),

url = window.URL.createObjectURL(blob);

var img = new Image();

img.width = 730;

img.height = 300;

img.onload = function(){

var canvas = document.createElement('canvas');

canvas.width = 730;

canvas.height = 300;

var ctx = canvas.getContext('2d');

ctx.drawImage(img, 0, 0, 730, 300);

window.URL.revokeObjectURL(url);

var canvasdata = canvas.toDataURL('image/png');

var a = document.getElementById('imgId');

a.download = "export_" + Date.now() + ".png";

a.href=canvasdata;

}

img.src = url

你的问题:

为什么图像只加载大约1/4的SVG?

回答:

只要按照这些规则:

< rect />的x < rect />的宽度< =< svg />的宽度

> y< rect /> < rect />的高度< =< svg />的高度

例如:

fill="none" stroke="blue" stroke-width="10" />

这里,< rect /> = 10,< rect />的宽度= 550,宽度< svg> = 500

因此,10 550> 500

在这种情况下,图像将被部分渲染.

希望这将解决你的问题.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值