我正在尝试在画布上绘制一个灰色渐变(或其中一些)。为此,我使用了画布的 getImageData() 和 putImageData() 方法。 data
是一个大小为 1000 * 1000 * 4 的 Uint8ClampedArray。在 for 循环中,数据的 rgb 颜色元素正确设置为 x%255,如将data
数组打印到控制台所示。然而,代码的结果与预期的不同。显示了一个完全白色的 cnvas,而预期有 4 个灰色渐变。
最小的工作示例:
<!DOCTYPE html>
<html>
<head>
</head>
<body>
<canvas id = "canvas" width = "1000" height = "1000"></canvas>
<script>
var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');
draw();
function draw(){
const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height);
const data = imageData.data;
for(let y = 0; y < canvas.height; y++){
for(let x = 0; x < canvas.width; x++){
for(let color = 0; color < 3; color++){
let idx = (y * canvas.width + x) * 4;
data[idx + color] = x % 255;
}
}
}
ctx.putImageData(imageData, 0, 0);
}
</script>
</body>
</html>