-1

I don't understand why the lines are diagonal and unevenly dotted. I'm trying to draw straight vertical lines.

'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>
GirkovArpa
  • 4,427
  • 4
  • 14
  • 43
  • 1
    remember: vertical lines start at some pixel's RGBA channels starting at `x`, then the next pixel to color is the RGBA values on `x + width*4` (because it's a clamped int array with 4 entries per pixel so one row is `width*4` values), then on `x + width*4 * 2` for the next line, then times three for the line after that, times four, five, etc. – Mike 'Pomax' Kamermans Oct 28 '20 at 00:50

1 Answers1

0

'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>
GirkovArpa
  • 4,427
  • 4
  • 14
  • 43