J'ai une image png colorée avec transparence. Je voudrais utiliser le filtre css pour rendre toute l'image blanche mais laisser la transparence telle quelle. Est-ce possible en CSS?
J'ai une image png colorée avec transparence. Je voudrais utiliser le filtre css pour rendre toute l'image blanche mais laisser la transparence telle quelle. Est-ce possible en CSS?
Réponses:
Vous pouvez utiliser
filter: brightness(0) invert(1);
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.
layout.css.filters.enabled
réglé sur true
.
brightness(infinity)
. Mais dans la pratique, brightness(10000%)
c'est assez haut pour le gris résultant decontrast(0)
À ma connaissance, il n'y a malheureusement pas de filtre CSS pour coloriser un élément (peut-être avec l'utilisation d'une magie de filtre SVG, mais je ne suis pas familier avec cela) et même si ce n'était pas le cas, les filtres ne sont fondamentalement supportés 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 RVBA respectives en fonction de la couleur souhaitée.
Cependant, les toiles sont soumises à 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 permettra pas de lire ou de modifier les données de pixels du canevas.
Voici un JSFiddle qui change 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>
filter
. Cependant, il n'est actuellement pris en charge que sur les navigateurs Webkit.