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

标签 javascript node.js svg png

我想在服务器上将一个简单的动态 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 步:使用 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() + '" />');
});

结果:
(在 Node v0.10.25 上运行。)

<img src="" />

<子> 特别感谢 this question对于 fabric.loadSVGFromString 示例。

关于javascript - 在 node.js 中将 SVG 代码转换为 PNG 数据 URI,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31766732/

相关文章:

javascript - angularjs 表达式中的注释

javascript - 为什么 JavaScript 中的 IF 语句允许重新声明变量

javascript - 使用 jQuery 的 .data() 查看附加到元素的所有数据?

css - 如何在保持宽高比和可伸缩性的同时使用 SVG Sprite Sheet 作为 CSS 背景图像

输出到 OpenGL(交互式)和 SVG(用于打印)的 Java 库

javascript - 使用 javascript 加载 XUL 资源

javascript - 当我在 Node js 中创建后调用时,为什么 Watson-conversation 对任何请求返回相同的默认响应

node.js - Electron - IPC改变对象

javascript - Node.js:将多个路由集中到一个路由文件中

animation - 为什么这个 SVG 动画不起作用