在Node.js中读取PNG图像

Node.js中有一种简单的方法来读取PNG文件并获取图像的像素? 像节点图像 ,但另一种方式:)

我浏览了https://github.com/joyent/node/wiki/modules#wiki-graphics上列出的库,但是它们是简单的命令行工具包装,提供裁剪和resize或者复杂的绘图工具,比如node-canvas

这一个PNG解码和编码没有本地依赖:

pngjs2 – 用于Node.js的PNG编码器/解码器,没有本地依赖性。

一个反转PNG颜色的例子:

 var fs = require('fs'), PNG = require('pngjs2').PNG; fs.createReadStream('in.png') .pipe(new PNG()) .on('parsed', function() { for (var y = 0; y < this.height; y++) { for (var x = 0; x < this.width; x++) { var idx = (this.width * y + x) << 2; // invert color this.data[idx] = 255 - this.data[idx]; this.data[idx+1] = 255 - this.data[idx+1]; this.data[idx+2] = 255 - this.data[idx+2]; // and reduce opacity this.data[idx+3] = this.data[idx+3] >> 1; } } this.pack().pipe(fs.createWriteStream('out.png')); }); 

我正在疯狂寻找,但我发现一个:

png.js – 用于canvas元素或Node.js的JS中的PNG解码器。

 var PNG = require('png-js'); var myimage = new PNG('myimage.png'); var width = myimage.width; var height = myimage.height; myimage.decode(function (pixels) { //Pixels is a 1D array containing pixel data }); 

请注意,这是纯粹的 JavaScript。 在浏览器 <canvas>Node.JS中都可以使用

除了widthheight之外,还有更多的属性,请参阅这个源文件 。

我认为

 var myimage = new PNG('myimage.png'); 

应该

 var myimage = new PNG.load('myimage.png'); 

看看Pedro Teixeira的这个剪影:

http://nodetuts.com/tutorials/3-flush-the-cat-filesystem-reading-files-streams-slow-clients-and-syspump.html#video

它演示了如何读取.jpg文件。 只需将“Content-Type”replace为“image / png”。