编程语言
首页 > 编程语言> > javascript-更改在HTML5画布元素上绘制的图像的颜色

javascript-更改在HTML5画布元素上绘制的图像的颜色

作者:互联网

我在这里有这张图片:

如何将整个颜色更改为用户定义的rgb值?

换句话说,给定灰度图像,我该如何将其切换回彩色,并且该彩色是任何rgb值.

解决方法:

感谢@Rikonator的评论,解决方案如下:

function changeColor(img, r, g, b) {
    var c = document.createElement('canvas');
    c.width = img.width;
    c.height = img.height;
    var ctx = c.getContext('2d');
    ctx.drawImage(img, 0, 0);
    var imgData=ctx.getImageData(0, 0, c.width, c.height);
    for (var i=0;i<imgData.data.length;i+=4)
    {
        imgData.data[i]= r | imgData.data[i];
        imgData.data[i+1]= g | imgData.data[i+1];
        imgData.data[i+2]= b | imgData.data[i+2];
    }
    ctx.putImageData(imgData,0,0);
    return c;
},  

标签:grayscale,html5,html5-canvas,javascript
来源: https://codeday.me/bug/20191031/1975709.html