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

前端之家收集整理的这篇文章主要介绍了javascript – 将SVG代码转换为node.js中的PNG数据URI前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想将简单的动态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.

解决方法

这是一个使用 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:运行以下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() + '" />');
});

结果:

(在节点v0.10.25上)

<img src="" />

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

猜你在找的JavaScript相关文章