it-swarm.com.ru

Фильтр CSS: сделать цветное изображение прозрачным белым

У меня есть цветное изображение PNG с прозрачностью. Я хотел бы использовать фильтр CSS, чтобы сделать все изображение белым, но оставить прозрачность как есть. Это возможно в CSS?

82
Pascal Klein

Ты можешь использовать

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) делает черные части белыми.

279
Oriol

Насколько мне известно, к сожалению, не существует CSS-фильтра для окрашивания элемента (возможно, с использованием некоторой магии фильтра SVG, но мне это немного не знакомо), и даже если это не так, фильтры в основном поддерживаются только веб-браузеры.

С учетом сказанного, вы все равно можете обойти это и использовать 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>
5
Daniel Perván