将画布或控制点转换为 SVG

2024-01-14

我正在开发一个绘图应用程序,现在我想添加一个从画布或控制点创建 SVG 的函数。 (我保存每个绘图步骤的鼠标坐标)。

canvasElement.toDataURL("image/svg+xml"); // -- doesn't work

一个条件 - 不要使用外部库。

据我所知,可以用 Javascript 生成 SVG 文件,如下所示:

var mysvg = "<svg>"; for(something) { mysvg += "something"; } //etc

但我不认为这是好方法。

你能提供什么建议吗?


我通过生成 SVG 文件解决了这个问题。我将所有画布绘图功能转换为 SVG 绘图标签。

像这样的东西:

function exportSVG() {
    var svg = '<?xml version="1.0" standalone="yes"?>';
svg += '<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">';
svg += '<svg width="1065px" height="529px" xmlns="http://www.w3.org/2000/svg" version="1.1">';

for(var i=0; i<myPoints.length; i++) {
   svg += "M"+myPoints.x[i]+","+myPoints.y[i]+" ";
   svg += "L"+myPoints.x[i+1]+","+myPoints.y[i+1];
   svg += '" fill="none" stroke="rgb('+color+')" stroke-opacity="'+opacity+'" stroke-width="'+size+'px" stroke-linecap="round" stroke-linejoin="round" />';
}
svg += "</svg>";
}

因此,在 svg 变量中将会有从 Canvas 生成的 SVG 文件。 谢谢大家!

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

将画布或控制点转换为 SVG 的相关文章

随机推荐