グレースケールに変換したいpng画像があります。私はそれをグレースケールに変換することができましたが、イメージの透明なアールの色も変わりました。 画像の透過領域を変更せずに色を変更するにはどうすればよいですか?画像の色をhtml5でグレースケールに変更
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);
完全にはサポートされていませんが、正確な質問には答えられていませんが、提供されるソリューションは標準に優しいため、クロムでは '-webkit-filter:grayscale(100%)' – andy