我有一个彩色的透明png图像。我想使用css过滤器,使整个图像白色,但留下透明度,因为它是。 这在CSS中可行吗?
当前回答
据我所知,遗憾的是,没有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>
其他回答
你可以使用
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>
推荐文章
- 为什么我的CSS3媒体查询不能在移动设备上工作?
- 下一个元素的CSS选择器语法是什么?
- 是否有'box-shadow-color'属性?
- 在jQuery中的CSS类更改上触发事件
- 我如何用CSS跨浏览器绘制垂直文本?
- 如何获得box-shadow在左侧和右侧
- 相对定位一个元素,而不占用文档流中的空间
- 禁用身体滚动
- 使用jQuery动画addClass/removeClass
- 在一个CSS宽度的小数点后的位置是尊重?
- 检测输入是否有文本在它使用CSS -在一个页面上,我正在访问和不控制?
- 我怎么能选择一个特定的类的最后一个元素,而不是父里面的最后一个孩子?
- @media screen和(max-width: 1024px)在CSS中是什么意思?
- 我怎么能检查html元素,从DOM消失失去焦点?
- 谷歌Chrome表单自动填充和它的黄色背景