将缓冲区响应从resemble.js写入文件

时间:2015-02-26 15:31:04

标签: node.js buffer resemblejs

我正在使用node-resemble-js来比较两张PNG图像。

比较没有问题,我得到了一个成功/相关的响应,但是我输出图像差异时遇到了问题。

var express = require('express');
var fs = require('fs');
var resemble = require('node-resemble-js');
var router = express.Router();

router.get('/compare', function(req, res, next) {
    compareImages(res);
});

var compareImages = function (res) {
    resemble.outputSettings({
        largeImageThreshold: 0
    });
    var diff = resemble('1.png')
        .compareTo('2.png')
        .ignoreColors()
        .onComplete(function(data){
            console.log(data);
            var png = data.getDiffImage();
            fs.writeFile('diff.png', png.data, null, function (err) {
                if (err) {
                    throw 'error writing file: ' + err;
                }
                console.log('file written');
            });
            res.render('compare');
        });
};

module.exports = router;

它按预期写入diff.png但是它没有创建有效的图像。

我出错的任何想法?感觉我很近,但不确定最后一块。

由于

1 个答案:

答案 0 :(得分:3)

看起来有一个需要调用的pack()方法,它可以完成一些工作然后流式传输数据。在这种情况下,您可以缓冲流,然后像这样调用writeFile:

        var png = data.getDiffImage();
        var buf = new Buffer([])
        var strm = png.pack()
        strm.on('data', function (dat) {
          buf = Buffer.concat([buf, dat])
        })
        strm.on('end', function() {
          fs.writeFile('diff.png', buf, null, function (err) {
            if (err) {
             throw 'error writing file: ' + err;
            }
            console.log('file written');
          })
        })

或者你可以像这样管道它,这有点简单:

png.pack().pipe(fs.createWriteStream('diff.png'))

老实说,你的方法对我来说很有意义(抓住缓冲区然后写它)但是我想data缓冲区附加到getDiffImage后面的缓冲区并不是最后的png。似乎文档有点薄,但这里有一些信息:https://github.com/lksv/node-resemble.js/issues/4