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

时间:2015-08-01 22:16:18

标签: javascript node.js svg png

我想将一个简单的动态svg片段转换为服务器上的PNG数据URI。像这样:

Config

我见过使用imagemagick和一些phantomJS变种的例子,但我正在寻找node.js中的动态动态解决方案,最好没有I / O.

2 个答案:

答案 0 :(得分:12)

以下是使用Fabric.js

的方法

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

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

第3步:使用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() + '" />');
});

结果:
(Ran on node v0.10.25。)

<img src="" />

<子> 特别感谢fabric.loadSVGFromString示例的this question

答案 1 :(得分:1)

看看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);
})();

免责声明:我是svg-to-img的作者。