簡體   English   中英

如何使用 ImageData 直接在畫布上繪制垂直線?

[英]How to draw vertical lines on canvas directly with ImageData?

我不明白為什么這些線是對角線且點不均勻。 我正在嘗試繪制直線垂直線。

 'use strict'; function loadImage(url) { return new Promise(r => { let i = new Image(); i.onload = (() => r(i)); i.src = url; }); } (async () => { const canvas = document.querySelector('canvas'); const context = canvas.getContext('2d'); const image = await loadImage(""); canvas.width = image.width; canvas.height = image.height; context.drawImage(image, 0, 0); const imageData = context.getImageData(0, 0, canvas.width, canvas.height); for (let i = 0; i < image.width * 4; i += 4) { for (let j = 0; j < image.height * 4; j += 4) { imageData.data[(i * j) + 0] = 0; imageData.data[(i * j) + 1] = 0; imageData.data[(i * j) + 2] = 0; imageData.data[(i * j) + 3] = 255; } } context.putImageData(imageData, 0, 0); })();
 html { background: yellow; } * { margin: 0; padding: 0; }
 <!DOCTYPE html> <html> <head> </head> <body> <canvas></canvas> </body> </html>

 'use strict'; function loadImage(url) { return new Promise(r => { let i = new Image(); i.onload = (() => r(i)); i.src = url; }); } (async () => { const canvas = document.querySelector('canvas'); const context = canvas.getContext('2d'); const image = await loadImage(""); canvas.width = image.width; canvas.height = image.height; context.drawImage(image, 0, 0); const imageData = context.getImageData(0, 0, canvas.width, canvas.height); for (let x = 0; x < canvas.height * 4; x += 1) { for (let y = 0; y < canvas.width * 4; y += 4 * 10) { const i = y + canvas.width * 4 * x; imageData.data[i + 0] = 0; imageData.data[i + 1] = 0; imageData.data[i + 2] = 0; imageData.data[i + 3] = 255; } } context.putImageData(imageData, 0, 0); })();
 html { background: yellow; } * { margin: 0; padding: 0; }
 <!DOCTYPE html> <html> <head> </head> <body> <canvas></canvas> </body> </html>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM