在node.js中将SVG代码转换为PNG数据URI [英] Convert SVG code into PNG data URI in node.js

查看:696
本文介绍了在node.js中将SVG代码转换为PNG数据URI的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想在服务器上将简单的动态svg代码段转换为PNG数据URI.像这样:

I’d like to convert a simple dynamic svg snippet into a PNG data URI on the server. Something like this:

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.

I’ve seen examples using imagemagick and some phantomJS variants, but I’m looking for an on-the-fly dynamic solution in node.js, preferably without I/O.

推荐答案

这是使用 Fabric.js 的一种方法a>:

Here's a way to do it using Fabric.js:

步骤1:安装开罗此处.)

Step 1: Install Cairo and node-canvas:
(I'm on Ubuntu 14.04, instructions for other OSes can be found 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:

Step 2: Install Fabric.js:

sudo npm install fabric

第3步:使用node运行以下JavaScript:

Step 3: Run the following JavaScript with node:

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上运行.)

Result:
(Ran on node v0.10.25.)

<img src="" />

特别感谢此问题作为fabric.loadSVGFromString示例.

Special thanks to this question for the fabric.loadSVGFromString example.

这篇关于在node.js中将SVG代码转换为PNG数据URI的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆