javascript - 如何在 JavaScript 中对 Canvas 图像进行灰度化?

标签 javascript html canvas grayscale imagedata

我有一个 HTML5 Canvas 内的图像,大小为 28x28 像素。我使用以下代码将 Canvas 的 imageData 获取为 RGBA(红、绿、蓝、alpha)值数组:

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

现在我想要对图像进行灰度化,以便获得一个包含 784 个值(28x28 像素)的数组,其中每个像素都有一个值(而不是四个)。

我发现了很多不同的灰度公式,有些是乘以 rgb 值,有些只是计算平均值 - 我真的不知道该使用哪一个......

我也被困在获取 784 个值 - 它始终是 3136(因为有 4 个 channel )...

提前致谢!

最佳答案

主要思想是使颜色的红绿和蓝色分量具有相同的值。为此,您需要计算每个像素的亮度。有多种计算亮度的方法。这是其中之一。

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" />

更新:
替代 lightness计算:

  • Wikipedia (亮度):
    let lightness = parseInt(pixels[i]*.299 + pixels[i + 1]*.587 + pixels[i + 2]*.114);

  • 其他地方(来源未知):
    let lightness = parseInt(3*pixels[i] + 4*pixels[i + 1] + pixels[i + 2] >>> 3);

  • Wikipedia (线性亮度):
    let lightness = 0.2126 * pixels[i] + 0.715 * pixels[i+1] + 0.0722 * pixels[i+2];

关于javascript - 如何在 JavaScript 中对 Canvas 图像进行灰度化?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53364140/

相关文章:

javascript - 尝试为 gmail 运行 google API quickstart,按照所有步骤进行操作,但出现错误

javascript - 如果输入文本不在数据列表中则禁用提交

javascript - jQuery - 复选框正在计数,但单击全选复选框时不计数

javascript - 使用 requestAnimationFrame 的简单球动画 HTML5

javascript - 在 html 中使用变量的更好方法

javascript - HTML5 Canvas : Bouncing Balls with Image Overlay

javascript - Canvas drawImage 在本地运行时抛出 INDEX_SIZE_ERR,而不是从网络运行

javascript - 有没有办法检查是否强制执行严格模式?

javascript - 包括需要很长时间才能加载,您可以看到它们正在加载

javascript - Fabric.js - 带有矩形的动态裁剪区域