I have a image that needs to converted to Uint8Array.
For Example:
var image = new Image();
image.src="image13.jpg";
Now i need to transform this image variable to Uint8Array. Is there any function in JS, which allows to achieve this functionality?
You may use the Canvas API to retrieve the image data:
async function imageToUint8Array(image, context) {
context.width = image.width;
context.height = image.height;
context.drawImage(image, 0, 0);
const blob = await context.canvas.toBlob(
callback,
"image/jpeg" // the MIME type of the image format
1 // quality (in the range 0..1)
);
return new Uint8Array(await blob.arrayBuffer());
}
function toBlob(canvas, type = "image/png", quality = 1) {
return new Promise((resolve) => canvas.toBlob(blob => resolve(blob)))
}
async function imageToUint8Array(image, context) {
context.width = image.width;
context.height = image.height;
context.drawImage(image, 0, 0);
const blob = await toBlob(context.canvas, "image/png");
return new Uint8Array(await blob.arrayBuffer());
}
const image = new Image();
// stackoverflow logo
image.src = ``;
const canvas = document.createElement("canvas");
const context = canvas.getContext("2d");
image.onload = async() => console.log(await imageToUint8Array(image, context));
function imageToUint8Array(image, context) {
context.width = image.width;
context.height = image.height;
context.drawImage(image, 0, 0);
// `getImageData().data` is a `Uint8ClampedArray`, which differs from `Uint8Array` only in
// how data is treated when values are being *set*, so it is valid to perform the conversion
// into a `Uint8Array`.
return new Uint8Array(context.getImageData(0, 0, image.width, image.height).data.buffer);
}
function imageToUint8Array(image, context) {
context.width = image.width;
context.height = image.height;
context.drawImage(image, 0, 0);
// `getImageData().data` is a `Uint8ClampedArray`, which differs from `Uint8Array` only in
// how data is treated when values are being *set*, so it is valid to perform the conversion
// into a `Uint8Array`.
return new Uint8Array(context.getImageData(0, 0, image.width, image.height).data.buffer);
}
const image = new Image();
// stackoverflow logo
image.src = ``;
const canvas = document.createElement("canvas");
const context = canvas.getContext("2d");
image.onload = async() => console.log(imageToUint8Array(image, context));
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With