Reputation: 13
I have got a image in my javascript code which is in base64 format as given below:
Img=image/jpeg;base64,/9j/4AAQSK.......
Now I want to convert this image into array using javascript.
Upvotes: 1
Views: 2396
Reputation: 981
function base64ToUint8Array(base64) {
const binary = atob(base64);
const len = binary.length;
const bytes = new Uint8Array(len);
for (let i = 0; i < len; i++)
bytes[i] = binary.charCodeAt(i);
return bytes;
}
base64ToUint8Array(YourBase64String)
function base64ToUint8Array(base64) {
const binary = atob(base64);
const len = binary.length;
const bytes = new Uint8Array(len);
for (let i = 0; i < len; i++)
bytes[i] = binary.charCodeAt(i);
return bytes;
}
const image = `Img=image/jpeg;base64,T25seUV4YW1wbGU=`
const base64 = image.split('base64,')[1]
console.log(base64ToUint8Array(base64))
Reference: Convert base64 string to ArrayBuffer
ArrayBuffer
instead of a Uint8Array
, you should return bytes.buffer
instead of bytes
Upvotes: 1
Reputation: 19493
Do you possibly mean a ImageData? it's a 1d array where each 4 consecutive numbers (bytes?) represent (r,g,b,a) with values 0..255
var str = ""
var canvas = document.createElement("canvas");
var ctx = canvas.getContext('2d');
var image = new Image()
image.onload = function() {
ctx.drawImage(image, 0, 0);
var imageData = ctx.getImageData(0, 0, image.width, image.height);
console.log(imageData)
}
image.src = str;
document.body.appendChild(canvas)
Upvotes: 2