mirror of
https://github.com/danbulant/pngjs
synced 2026-06-19 22:41:58 +00:00
Merge branch 'master' of github.com:lukeapage/node-pngjs2
This commit is contained in:
commit
f84416a523
5 changed files with 15 additions and 6 deletions
|
|
@ -23,12 +23,16 @@ var Packer = module.exports = function(options) {
|
|||
util.inherits(Packer, Stream);
|
||||
|
||||
|
||||
Packer.prototype.pack = function(data, width, height) {
|
||||
Packer.prototype.pack = function(data, width, height, gamma) {
|
||||
|
||||
// Signature
|
||||
this.emit('data', new Buffer(constants.PNG_SIGNATURE));
|
||||
this.emit('data', this._packIHDR(width, height));
|
||||
|
||||
if (gamma) {
|
||||
this.emit('data', this._packGAMA(gamma));
|
||||
}
|
||||
|
||||
// filter pixel data
|
||||
//TODO {}
|
||||
var filter = new Filter(width, height, 4, 8, false, this._options, {});
|
||||
|
|
@ -70,6 +74,12 @@ Packer.prototype._packChunk = function(type, data) {
|
|||
return buf;
|
||||
};
|
||||
|
||||
Packer.prototype._packGAMA = function(gamma) {
|
||||
var buf = new Buffer(4);
|
||||
buf.writeUInt32BE(Math.floor(gamma * 100000), 0); // TODO constant
|
||||
return this._packChunk(constants.TYPE_gAMA, buf);
|
||||
};
|
||||
|
||||
Packer.prototype._packIHDR = function(width, height) {
|
||||
|
||||
var buf = new Buffer(13);
|
||||
|
|
|
|||
|
|
@ -249,7 +249,7 @@ Parser.prototype._handleGAMA = function(length) {
|
|||
Parser.prototype._parseGAMA = function(data) {
|
||||
|
||||
this._crc.write(data);
|
||||
this.gamma(data.readUInt32BE(0) / 100000);
|
||||
this.gamma(data.readUInt32BE(0) / 100000); //TODO constant
|
||||
|
||||
this._handleChunkEnd();
|
||||
};
|
||||
|
|
|
|||
|
|
@ -55,7 +55,7 @@ PNG.prototype.pack = function() {
|
|||
}
|
||||
|
||||
process.nextTick(function() {
|
||||
this._packer.pack(this.data, this.width, this.height);
|
||||
this._packer.pack(this.data, this.width, this.height, this.gamma);
|
||||
}.bind(this));
|
||||
|
||||
return this;
|
||||
|
|
|
|||
|
|
@ -1,7 +1,7 @@
|
|||
{
|
||||
"name": "pngjs2",
|
||||
"version": "0.0.3",
|
||||
"description": "Pure JS PNG encoder/decoder",
|
||||
"description": "PNG encoder/decoder in pure JS, supporting any bit size & interlace, async & sync with full test suite.",
|
||||
"contributors": [
|
||||
"Alexandre Paré",
|
||||
"Gaurav Mali",
|
||||
|
|
|
|||
|
|
@ -57,7 +57,7 @@ module.exports = function(done) {
|
|||
} else {
|
||||
|
||||
var outpng = new PNG();
|
||||
//PNG.adjustGamma(png);
|
||||
outpng.gamma = png.gamma;
|
||||
outpng.data = png.data;
|
||||
outpng.width = png.width;
|
||||
outpng.height = png.height;
|
||||
|
|
@ -82,7 +82,6 @@ module.exports = function(done) {
|
|||
if (expectedError) {
|
||||
console.log("Async: Error expected, parsed fine ..", file);
|
||||
}
|
||||
//this.adjustGamma();
|
||||
|
||||
this.pack()
|
||||
.pipe(
|
||||
|
|
|
|||
Loading…
Reference in a new issue