问题描述
我目前正在尝试在 JavaScript 中将 base64Encoded 字符串(图像表示)转换为 ImageData 对象。但是,这会返回一个错误:
未捕获的 InvalidStateError: 无法构造 'ImageData': 输入数据长度不是 4 的倍数。
编码图像为 940 x 740
我错过了什么?任何帮助表示赞赏
function _base64ToArrayBuffer(base64) {
var binary_string = window.atob(base64);
var len = binary_string.length;
var bytes = new Uint8Array(len);
for (var i = 0; i < len; i++) {
bytes[i] = binary_string.charCodeAt(i);
}
return bytes.buffer;
}
const base64String = ""; //truncated because stackoverflow question too long.
const arrBuffer = _base64ToArrayBuffer (base64String );
var array = new Uint8ClampedArray(arrBuffer);
console.log(array);
var image = new ImageData(array,900,740);
console.log(image);
解决方法
您可以从 Canvas 获取 ImageData
function _base64ToImageData(buffer,width,height) {
return new Promise(resolve => {
var image = new Image();
image.addEventListener('load',function (e) {
var canvasElement = document.createElement('canvas');
canvasElement.width = width;
canvasElement.height = height;
var context = canvasElement.getContext('2d');
context.drawImage(e.target,height);
resolve(context.getImageData(0,height));
});
image.src = 'data:image/png;base64,' + buffer;
document.body.appendChild(image);
setTimeout(() => {
document.body.removeChild(image);
},1);
});
}
window.addEventListener('load',() => {
_base64ToImageData(base64String,2056,1236).then(data => {
console.log(data);
});
});