无法从 ImageData 对象获取像素

Can't get the pixels from ImageData object

我正在尝试使用 canvas 元素和 ImageData class 从图像中提取像素,但收效甚微。

我的代码是:

var image = new Image();
image.src = "<path to PNG image file>";
var context = document.getElementById("my-canvas").getContext("2d");
context.drawImage(image, 0, 0);
var imageData = context.getImageData(0, 0, 1024, 1024);
console.log(imageData);

canvas 定义如下:

<canvas id ="my-canvas" width="1024" height="1024">
</canvas>

根据 MDNdata 字段应该是 4194304 (1024*1024*4) 大小的 UInt8 数组。相反,我得到一个奇怪的嵌套结构(如图所示),所有值都是 0。图像是 1024*1024 PNG 图像。

我哪里做错了?

您应该等到您的 PNG 加载完毕(ImageData 用零初始化):

var image = new Image();
image.onload = extractPixelsFromPNG;
image.src = "<path to PNG image file>";
var context = document.getElementById("my-canvas").getContext("2d");

function extractPixelsFromPNG() {
    context.drawImage(image, 0, 0);
    var imageData = context.getImageData(0, 0, 1024, 1024);
    console.log(imageData);
}