CSS滤镜:使彩色图像具有透明的白色


149

我有一个透明的彩色png图像。我想使用css过滤器使整个图像变白,但保持透明度不变。CSS有可能吗?


1
你可以试试看filter。不过,目前仅在Webkit浏览器中支持它。
Oriol 2014年

我知道我可以尝试使用过滤器,但是应该使用哪个过滤器?我想查看确切的CSS代码。
Pascal Klein 2014年

Answers:


470

您可以使用

filter: brightness(0) invert(1);

首先,brightness(0)使所有图像变黑,但透明部分除外,这些部分保持透明。

然后,invert(1)使黑色部分变白。


1
@DanielPerván可以在Firefox 34(layout.css.filters.enabled设置为)上使用true
Oriol 2014年

1
@Gorg理论上应该是brightness(infinity)。但是在实践brightness(10000%)中,对于因以下原因产生的灰色效果足够高了contrast(0)
Oriol

@Oriol 200 IQ开发人员
maxpaj

自60.0.1(2018年6月)起即可使用Firefox
Sablefoste

4
@MahmudulHaque您正在回复2014年的评论。在那些年中,已经有33个主要版本的Firefox,而IE则从世界第二大流行的浏览器发展到如今已经死亡。
DanielPerván18年

8

据我所知,遗憾的是没有CSS过滤器可以为元素着色(也许使用了一些SVG过滤器魔术,但我对此并不熟悉),即使不是这种情况,过滤器基本上仅受支持webkit浏览器。

话虽如此,您仍然可以解决此问题,并使用canvas修改您的图片。基本上,您可以在画布上绘制图像元素,然后遍历像素,将相应的RGBA值修改为所需的颜色。

但是,画布确实有一些限制。最重要的是,您必须确保图像src来自与页面相同的域。否则,浏览器将不允许您读取或修改画布的像素数据。

这是一个JSFiddle,它更改了JSFiddle徽标的颜色。

//Base64 source, but any local source will work
var src = "";
var canvas = document.getElementById("theCanvas");
var ctx = canvas.getContext("2d");
var img = new Image;

//wait for the image to load
img.onload = function() {
    //Draw the original image so that you can fetch the colour data
    ctx.drawImage(img,0,0);
    var imgData = ctx.getImageData(0, 0, canvas.width, canvas.height);
    
    /*
    imgData.data is a one-dimensional array which contains 
    the respective RGBA values for every pixel 
    in the selected region of the context 
    (note i+=4 in the loop)
    */
    
    for (var i = 0; i < imgData.data.length; i+=4) {
			imgData.data[i] = 255; //Red, 0-255
			imgData.data[i+1] = 255; //Green, 0-255
			imgData.data[i+2] = 255; //Blue, 0-255
			/* 
			imgData.data[i+3] contains the alpha value
			which we are going to ignore and leave
			alone with its original value
			*/
    }
    ctx.clearRect(0, 0, canvas.width, canvas.height); //clear the original image
    ctx.putImageData(imgData, 0, 0); //paint the new colorised image
}

//Load the image!
img.src = src;
body {
    background: green;
}
<canvas id="theCanvas"></canvas>

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.