web-dev-qa-db-fra.com

Filtre CSS: crée une image couleur avec une transparence blanche

J'ai une image png colorée avec transparence. Je voudrais utiliser le filtre CSS pour rendre toute l'image blanche mais laisser le transparent tel quel. Est-ce possible en CSS?

90
Pascal Klein

Vous pouvez utiliser

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>

Tout d'abord, brightness(0) rend toutes les images noires, à l'exception des parties transparentes, qui restent transparentes.

Ensuite, invert(1) rend les parties noires blanches.

297
Oriol

À ma connaissance, il n’existe malheureusement aucun filtre CSS pour coloriser un élément (peut-être avec l’utilisation de la magie du filtre SVG, mais je ne le connais pas très bien) et même si ce n’était pas le cas, les filtres ne sont fondamentalement pris en charge que par navigateurs webkit.

Cela dit, vous pouvez toujours contourner ce problème et utiliser un canvas pour modifier votre image. Fondamentalement, vous pouvez dessiner un élément d'image sur un canevas, puis parcourir les pixels, en modifiant les valeurs RGBA respectives en fonction de la couleur souhaitée.

Cependant, les toiles viennent avec certaines restrictions. Plus important encore, vous devez vous assurer que l'image src provient du même domaine que la page. Sinon, le navigateur ne vous autorisera pas à lire ou à modifier les données de pixels du canevas.

Voici un JSFiddle changer la couleur du logo 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