在Node.js中有没有一种简单的方法来读取PNG文件并获取图像的像素?就像node-image这样的东西,但是反过来 :)
我研究了https://github.com/joyent/node/wiki/modules#wiki-graphics列出的库,但它们要么是围绕命令行工具提供裁剪和缩放的简单包装器,要么是像 node-canvas
这样的复杂绘图工具。
在Node.js中有没有一种简单的方法来读取PNG文件并获取图像的像素?就像node-image这样的东西,但是反过来 :)
我研究了https://github.com/joyent/node/wiki/modules#wiki-graphics列出的库,但它们要么是围绕命令行工具提供裁剪和缩放的简单包装器,要么是像 node-canvas
这样的复杂绘图工具。
这个可以同时进行PNG解码和编码,而不需要原生依赖:
pngjs - 一款适用于Node.js的PNG编码器/解码器,无需使用原生依赖。
一个反转PNG颜色的例子:
var fs = require('fs'),
PNG = require('pngjs').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]; // R
this.data[idx+1] = 255 - this.data[idx+1]; // G
this.data[idx+2] = 255 - this.data[idx+2]; // B
// 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
});
Buffer
。事实上,我一直在使用new PNG('image.png')
而没有任何问题。但是知道这点也很好! - Alba Mendez/home/anderson/node_modules/png-js/png-node.js:140 throw new Error("Incomplete or corrupt PNG file");
。我指定了现有图像的路径,那么为什么会发生这种情况呢? - Anderson Greennode-pngjs
。它具有更多的功能,如编码和增量处理。请参见下一个答案。 - Alba Mendez我认为
var myimage = new PNG('myimage.png');
应该是
var myimage = new PNG.load('myimage.png');
fs.readFile (err, data) -> image = new PNG(data)
。 - Jan Špaček