Feature request: Support for image compression
Aarbel opened this issue · 9 comments
Libraries like https://www.npmjs.com/package/browser-image-resizer allow to compress drastically images client side (set maxWidth and maxHeight, but also reducing file size)
Is there a way to achieve that with blueimp-load-image ?
Thanks a for your help !
Hi @Aarbel,
you can already reduce the size of images loaded via loadImage
by scaling them down in size and by using the quality argument for the browser-native canvas.toBlob function.
e.g. the following exports a JPEG blob with a quality of 0.5
:
canvas.toBlob(callback, 'image/jpeg', 0.5);
In browsers that support it, you can control the scaling algorithm used by the browser canvas implementation via the imageSmoothingEnabled and imageSmoothingQuality options for loadImage
.
The library you linked to seems to use bilinear interpolation implemented in JavaScript for image scaling - as far as I know, browsers already use bilinear interpolation by default in their canvas drawImage
implementation, unless imageSmoothingQuality
is set to high, which apparently uses Lanczos from what I've read.
So altogether I don't see a good reason to not rely on the browser-provided implementations.
@blueimp thanks a lot for the detailed feedback.
Do you think browsers like iOS Safari or Old Edge can support it ?
Do i need particular polyfills to make it work ?
The canvas.toBlob
documentation I linked above has a browser compatibility table at the end:
https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob#Browser_compatibility
I'm also maintaining a polyfill for older browsers (e.g. IE) as well:
https://github.com/blueimp/JavaScript-Canvas-to-Blob
Great, i will investigate and compare the two solutions
With the information provided above, I assume you're fine with closing this?
Closing as solved.
@blueimp sorry didn't saw your comments. Possible to re-open this issue ?
Standard browser image compression doesn't work well in many environments (WkWebview for example).
Still using browser-image-resizer
at the moment, but uses a lot of cache / RAM in the browser because in perform two conversions (one with your lib, then one with browser-image-resizer
)