【问题标题】:change color of image to greyscale in html5在html5中将图像的颜色更改为灰度
【发布时间】:2013-09-26 12:54:03
【问题描述】:

我有一个 png 图像,我想将其转换为灰度。我设法将它转换为灰度,但它也改变了图像透明区域的颜色。 如何在不改变图像透明区域的情况下改变其颜色?

var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');
var img = new Image();
img.src = 'image.png';
ctx.drawImage(img, 0, 0);

var imageData = ctx.getImageData(0, 0, 420, 420);
var px = imageData.data;

var len = px.length;

for (var i = 0; i < len; i+=4) {
    var redPx = px[i];
    var greenPx = px[i+1];
    var bluePx = px[i+2];
    var alphaPx = px[i+3];

    var greyScale = redPx * .3 + greenPx * .59 + bluePx * .11;

    px[i] = greyScale;
    px[i+1] = greyScale;
    px[i+2] = greyScale;
    px[i+3] = greyScale;
}

ctx.putImageData(imageData, 0, 0);

【问题讨论】:

  • 虽然不完全支持,但是在chrome中你可以使用-webkit-filter: grayscale(100%)

标签: javascript jquery html


【解决方案1】:

Alpha 不是“颜色”。您应该照原样复制它,使透明部分保持透明。只需删除该行:

px[i+3] = greyScale;

【讨论】:

    【解决方案2】:

    我不完全确定这样做的目的,但由于该问题也被标记为“HTML5”,我认为它可能需要用于不同于例如图像处理库。如果这不是某种图像编辑器或 HTML5 游戏,您只需将一些图像转换为灰度,例如在悬停时,你也可以使用 CSS:

    .grayscale {
        filter: url("data:image/svg+xml;utf8,<svg xmlns=\'http://www.w3.org/2000/svg\'><filter id=\'grayscale\'><feColorMatrix type=\'matrix\' values=\'0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\'/></filter></svg>#grayscale"); /* Firefox 10+, Firefox on Android */
        filter: gray; /* IE6-9 */
        -webkit-filter: grayscale(100%); /* Chrome 19+, Safari 6+, Safari 6+ iOS */
    }
    

    如果这不合适,请发布更多信息,说明为什么需要这样做

    【讨论】:

    • 对该答案+1,因为虽然没有回答确切的问题,但提供的解决方案比原始问题本身更符合标准。
    【解决方案3】:

    这个插件 (tancolor.js) 做了你想要实现的类似的事情,你可以尝试检查 source code 并且有一个 intractive demo 供你测试。

    【讨论】:

      猜你喜欢
      • 2021-08-08
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-05-23
      • 1970-01-01
      • 2013-05-08
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多