CSS фильтр: сделать цветное изображение с прозрачностью белого цвета
У меня есть цветное изображение png с прозрачностью. Я хотел бы использовать css-фильтр, чтобы сделать все изображение белым, но оставить прозрачность как есть. Это возможно в CSS?
2 ответа:
можно использовать
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)
делает черные части белыми.
насколько мне известно, к сожалению, нет фильтра 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>