在Node.js中有一种简单的方法来读取PNG文件并获取图像的像素吗?像节点图像,但另一种方式:)
我浏览了https://github.com/joyent/node/wiki/modules#wiki-graphics中列出的库,但它们或者是命令行工具的简单包装器,提供裁剪和调整大小或复杂的绘图工具node-canvas.
小智 20
这个没有本机依赖性的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];
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'));
});
Run Code Online (Sandbox Code Playgroud)
Alb*_*dez 16
我快要疯了,但我发现了一个:
png.js - JS中用于canvas元素或Node.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
});
Run Code Online (Sandbox Code Playgroud)
请注意它是纯 JavaScript.无论是在作品的浏览器 <canvas>和Node.js的.
除了width和之外还有更多属性height,请参阅此来源.
| 归档时间: |
|
| 查看次数: |
27065 次 |
| 最近记录: |