Package Exports
- imagemagick-stream
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (imagemagick-stream) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
imagemagick-stream
Streaming imagemagick api
Install
$ npm install imagemagick-streamUsage
const im = require('imagemagick-stream');
const read = fs.createReadStream('image.png');
const write = fs.createWriteStream('image-resized.png');
const resize = im().resize('200x200').quality(90);
read.pipe(resize).pipe(write);For convenience, you can also pass the input filename to the constructor and the output filename to the .to() method.
im('image.png')
.resize('200x200')
.quality(90)
.to('image-resized.png');To use settings and operators that are not currently part of the API, please submit a pull request, or use the .set() and .op() methods.
See the imagemagick docs for a list of available options.
im('image.png')
.set('density', 400)
.set('channel', 'RGB')
.resize('200x200')
.op('gaussian-blur', 0.05)
.to('image-resized.png');NOTE: You shold listen to the finish event on the writable stream you're piping to, not the stream from ImageMagick:
const read = fs.createReadStream('image.png');
const write = fs.createWriteStream('image-resized.png');
im().resize('200x200').quality(90).pipe(write);
write.on('finish', () => {
// finished writing
});License
MIT