在node.js中将SVG代码转换为PNG数据URI

12
我想在服务器上将一个简单的动态 SVG 代码片段转换成 PNG 数据 URI。就像这样:
var svg = '<svg height="100" width="100"><circle cx="50" cy="50" r="40" stroke="black" stroke-width="3" fill="red" /></svg>'

console.log('<img src="data:image/png;base64,'+toPng(svg, 100, 100)+'">')

我看过使用imagemagick和一些phantomJS变体的示例,但我正在寻找一个在node.js中实时动态解决方案,最好不需要I/O。


嘿,你可以查看这个SO答案:https://dev59.com/3G865IYBdhLWcg3wHK3u - Daemedeor
这并不容易,因为对于非 JS 库进行转换而不生成进程是很困难的。 - Onur Yıldırım
2个回答

14

以下是使用Fabric.js的方法:

步骤1:安装Caironode-canvas
(我在Ubuntu 14.04上,其他操作系统的说明可以在这里找到。)

sudo apt-get update
sudo apt-get install libcairo2-dev libjpeg8-dev libpango1.0-dev libgif-dev build-essential g++
sudo npm install canvas

步骤2:安装Fabric.js:

sudo npm install fabric

第三步:使用node运行以下JavaScript代码:

var fabric = require('fabric').fabric;
var canvas = new fabric.createCanvasForNode(100, 100);
var svgStr = '<svg height="100" width="100"><circle cx="50" cy="50" r="40" stroke="black" stroke-width="3" fill="red" /></svg>';

fabric.loadSVGFromString(svgStr, function(objects, options) {
  var obj = new fabric.PathGroup(objects, options);
  canvas.add(obj);            
  console.log('<img src="' + canvas.toDataURL() + '" />');
});

Result:
(Ran on node v0.10.25.)

<img src="" />

特别感谢这个问题fabric.loadSVGFromString提供了示例。


2

请看svg-to-img

它在底层使用headless Chrome完成转换。

要在您的项目中使用svg-to-img,请运行:

npm install svg-to-img

以下是将svg转换为base64编码的png的方法:

const svgToImg = require("svg-to-img");

(async () => {
  const svg = "<svg xmlns='http://www.w3.org/2000/svg'/>";
  const png = await svgToImg.from(svg).toPng({ encoding: "base64" });

  console.log("data:image/png;base64," + png);
})();

Disclaimer: I'm the author of svg-to-img.


能否将SVG动画渲染成图像序列? - Akshay Kumar
@AkshayKumar 目前这个库还不支持,但你可以尝试自己实现。 - Etienne Martin

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接