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?
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.
À 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>