我有一个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);
答案 0 :(得分:9)
Alpha是“不是颜色”。您应该按原样复制它,使透明部分保持透明。只需删除该行:
px[i+3] = greyScale;
答案 1 :(得分:1)
我不完全确定这个目的,但由于这个问题也标记为“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 */
}
如果不合适,请发布有关您为什么需要这样做的更多信息
答案 2 :(得分:0)
此插件(tancolor.js)执行与您想要实现的类似的操作,您可以尝试检查source code并且有一个intractive demo供您测试。