CSSfilter:使透明度为白色的彩色图像

我有一个透明的彩色PNG图像。 我想使用CSSfilter,使整个图像白色,但保持透明度,因为它是。 这是可能的CSS?

您可以使用

 filter: brightness(0) invert(1); 
 html { background: red; } p { float: left; max-width: 50%; text-align: center; } img { display: block; max-width: 100%; } .filter { -webkit-filter: brightness(0) invert(1); filter: brightness(0) invert(1); } 
 <p> Original: <img src="http://i.stack.imgur.com/jO8jP.gif" /> </p> <p> Filter: <img src="http://i.stack.imgur.com/jO8jP.gif" class="filter" /> </p> 

据我所知,可悲的是没有CSSfilter着色一个元素(也许使用一些SVGfilter魔术,但我有点不熟悉),即使不是这样,filter基本上只支持webkit浏览器。

这样说,你仍然可以解决这个问题,并使用canvas来修改你的图像。 基本上,您可以在canvas上绘制图像元素,然后循环显示像素,将相应的RGBA值修改为所需的颜色。

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

这里有一个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>