我想将一个简单的动态svg片段转换为服务器上的PNG数据URI。像这样:
Config
我见过使用imagemagick和一些phantomJS变种的例子,但我正在寻找node.js中的动态动态解决方案,最好没有I / O.
答案 0 :(得分:12)
以下是使用Fabric.js:
的方法第1步:安装Cairo和node-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的作者。