Get image dimensions from stream
npm install image-dimensions-streamA Node module to get dimensions of any image file stream
* BMP
* GIF
* JPEG
* PNG
* PSD
* DDS
* SWF
* CUR
* ICO
* ICNS
* TIFF
* WebP
* SVG
```
yarn add image-dimensions-stream
`javascript
const ImageDimensionsStream = require('image-dimensions-stream');
const pipeline = util.promisify(require('stream').pipeline);
async function main() {
const sizeStream = new ImageDimensionsStream();
let result = {
mime: null,
dimensions: null,
};
sizeStream.on('mime', (mime) => {
console.log('mime:', mime);
result.mime = mime;
});
sizeStream.on('dimensions', (dimensions) => {
console.log('dimensions:', dimensions);
result.dimensions = dimensions;
});
await pipeline(fs.createReadStream('images/funny-cats.png'), sizeStream, fs.createWriteStream('/dev/null'));
return result;
}
main().then(console.log).catch(console.error);
`
Key | Type | Default | Description
--- | --- | --- | ---
requireMime | boolean function | true | destroy stream if mime can't be foundrequireDimensions | boolean function | true | destroy stream if dimensions can't be foundexif | boolean function | false | use EXIF (Orientation) data if availablerequireValidExif | boolean function | false | destroy stream on invalid EXIF data otherwise just skip EXIF block. Only useful if exif option returns truemaxMimeChunkOffset | number | Minimum value possible | Whether to destroy the stream if we couldn't detect mime type after reading this amount of bytesmaxMimeBufferSize | number in bytes | 4100 | Maximum buffer size when detecting mime typemaxDimensionsBufferSize | number` in bytes | 64000 | Maximum buffer size when detecting dimensions
image-size for test images and file structures