CSS滤镜:将带透明度的彩色图像转换为白色

286

我有一张带透明背景的彩色png图像。我想使用CSS滤镜将整个图像变成白色,但保留透明度。在CSS中是否可能实现这一效果?


1
你可以尝试使用 filter。不过目前只支持 Webkit 浏览器。 - Oriol
我知道我可以尝试使用过滤器,但是我应该使用哪种过滤器呢?我想看到确切的CSS代码。 - Pascal Klein
http://jsfiddle.net/Paulie_D/zAh8a/3/ - Paulie_D
2个回答

901

您可以使用

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>

首先,brightness(0) 使所有图像变黑,除了透明部分仍然保持透明。

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


1
@DanielPerván 它在 Firefox 34 上运行,需要将 layout.css.filters.enabled 设置为 true - Oriol
1
@Gorg 理论上应该是 brightness(infinity)。但在实践中,brightness(10000%) 对于由 contrast(0) 产生的灰色已经足够高了。 - Oriol
7
@Oriol 200 IQ developer @Oriol是200智商的开发者。 - maxpaj
6
您在回复一条来自于2014年的评论。这些年间,Firefox已经有了33个主要版本,而IE已经从全球第二流行的浏览器几乎消失不见。 - Daniel Perván
5
太棒了,解决了我的难题,节省了好几个小时的时间。 - sanjeev shetty
显示剩余4条评论

10
据我所知,遗憾的是没有CSS滤镜可以给一个元素上色(也许可以使用一些SVG滤镜魔法,但我对此不太熟悉)。即使这不是问题,过滤器基本上只受WebKit浏览器支持。
话虽如此,你仍然可以通过使用canvas来修改你的图片。基本上,你可以将一个图像元素绘制到画布上,然后循环遍历像素,将相应的RGBA值修改为所需颜色。
然而,canvas确实有一些限制。最重要的是,你必须确保图像的src来自于同一域名下的页面。否则,浏览器将不允许你读取或修改画布的像素数据。
这里是一个JSFiddle,可以改变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>


1
另一个重要的注意事项是,对于许多目的来说,每个图像像素运行一行JavaScript代码将会非常慢。 - Ted Brownlow

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接