Как я могу серого изображения холста в JavaScript? - PullRequest
0 голосов
/ 18 ноября 2018

У меня есть изображение внутри HTML5-холста размером 28x28 пикселей. Я получаю imageData холста в виде массива значений RGBA (красный, зеленый, синий, альфа), используя этот код:

canvas = document.getElementById('canvas');
ctx = canvas.getContext("2d");
imgData = ctx.getImageData(0, 0, 28, 28);

Теперь я хочу сделать изображение в градациях серого, чтобы получить массив из 784 значений (28x28 пикселей), где каждый пиксель имеет одно значение (вместо четырех).

Я нашел много различных формул для градации серого, некоторые умножают значения rgb, некоторые просто вычисляют среднее - я действительно не знаю, какую из них использовать ...

Я также застрял в получении 784 значений - это всегда 3136 (из-за 4 каналов) ...

Заранее спасибо!

1 Ответ

0 голосов
/ 18 ноября 2018

Основная идея заключается в том, чтобы иметь одинаковое значение для красного, зеленого и синего компонентов цвета. Для этого вам нужно рассчитать яркость каждого пикселя. Есть несколько способов рассчитать легкость. Это один из них.

window.onload = function() {
let canvas = document.getElementById("c");

	  let ctx = canvas.getContext("2d");
    canvas.width=50;
    canvas.height=50;

		let srcImg = document.getElementById("sof");
		ctx.drawImage(srcImg, 0, 0, ctx.canvas.width, ctx.canvas.height);
		let imgData = ctx.getImageData(0, 0, ctx.canvas.width, ctx.canvas.height);
		let pixels = imgData.data;
		for (var i = 0; i < pixels.length; i += 4) {
		  
		let lightness = parseInt((pixels[i] + pixels[i + 1] + pixels[i + 2])/3);
    
		  pixels[i] = lightness; 
		  pixels[i + 1] = lightness; 
		  pixels[i + 2] = lightness; 
		}
		ctx.putImageData(imgData, 0, 0);
	  }
<canvas id="c"></canvas>
<img src="" id="sof" />

UPDATE

Это еще одна формула легкости из Википедии

let lightness = parseInt(pixels[i]*.299 + pixels[i + 1]*.587 + pixels[i + 2]*.114);

Это еще одна формула, которую я нашел в Google:

let lightness = parseInt(3*pixels[i] + 4*pixels[i + 1] + pixels[i + 2] >>> 3);
...