我有一个彩色的透明png图像。我想使用css过滤器,使整个图像白色,但留下透明度,因为它是。 这在CSS中可行吗?
你可以使用
filter: brightness(0) invert(1);
html { 背景:红色; } p { 浮:左; max-width: 50%; text-align:中心; } img { 显示:块; max-width: 100%; } .filter { -webkit-filter:亮度(0)反转(1); 滤镜:亮度(0)反转(1); } < p > 原: <img src="http://i.stack.imgur.com/jO8jP.gif" /> < / p > < p > 过滤器: <img src="http://i.stack.imgur.com/jO8jP.gif" class="filter" /> < / p >
首先,亮度(0)使所有图像都是黑色的,除了透明部分,它仍然是透明的。
然后,invert(1)将黑色部分变成白色。
据我所知,遗憾的是,没有CSS过滤器来给元素上色(可能是使用了一些SVG过滤器的魔法,但我对它有点不熟悉),即使不是这样,过滤器基本上也只有webkit浏览器支持。
尽管如此,你仍然可以使用画布来修改你的图像。基本上,你可以在画布上绘制一个图像元素,然后循环像素,将各自的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>