it-swarm.com.de

CSS-Filter: Farbbilder mit Transparenz in Weiß erstellen

Ich habe ein farbiges PNG-Bild mit Transparenz. Ich möchte CSS-Filter verwenden, um das gesamte Bild weiß zu machen, aber die Transparenz so lassen, wie sie ist. Ist das in CSS möglich?

90
Pascal Klein

Sie können verwenden

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>

Erstens macht brightness(0) das gesamte Bild schwarz, mit Ausnahme der transparenten Teile, die transparent bleiben.

Dann macht invert(1) die schwarzen Teile weiß.

297
Oriol

Meines Wissens gibt es leider keinen CSS-Filter, um ein Element einzufärben (vielleicht mit etwas SVG-Filtermagie, aber ich bin damit nicht vertraut), und selbst wenn das nicht der Fall wäre, werden Filter grundsätzlich nur von unterstützt Webkit-Browser.

Sie können dies trotzdem umgehen und ein canvas verwenden, um Ihr Bild zu ändern. Grundsätzlich können Sie ein Bildelement auf eine Leinwand zeichnen und dann die Pixel durchlaufen, wobei Sie die jeweiligen RGBA-Werte auf die gewünschte Farbe einstellen.

Für Leinwände gelten jedoch einige Einschränkungen. Am wichtigsten ist, dass Sie sicherstellen, dass das Bild src aus derselben Domäne stammt wie die Seite. Andernfalls können Sie im Browser die Pixeldaten der Zeichenfläche nicht lesen oder ändern.

Hier ist ein JSFiddle Ändern der Farbe des JSFiddle-Logos.

//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