oscurecer - opacidad imagen de fondo css
Filtro CSS: hacer una imagen en color con transparencia blanca (2)
Puedes usar
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>
Primero, el brightness(0)
hace que toda la imagen sea negra, excepto las partes transparentes, que permanecen transparentes.
Luego, invert(1)
hace que las partes negras sean blancas.
Tengo una imagen png de color con transparencia. Me gustaría utilizar el filtro CSS para hacer que toda la imagen sea blanca, pero deje la transparencia tal como está. ¿Es eso posible en CSS?
Que yo sepa, lamentablemente no hay filtro CSS para colorear un elemento (quizás con el uso de algunos filtros SVG mágicos, pero no estoy familiarizado con eso) y aunque ese no fuera el caso, los filtros son básicamente compatibles solo con navegadores webkit.
Dicho esto, aún podrías solucionar esto y usar un canvas
para modificar tu imagen. Básicamente, puede dibujar un elemento de imagen en un lienzo y luego recorrer los píxeles, modificando los valores RGBA respectivos al color que desee.
Sin embargo, los lienzos vienen con algunas restricciones. Lo que es más importante, debe asegurarse de que la fuente de la imagen provenga del mismo dominio que la página. De lo contrario, el navegador no le permitirá leer o modificar los datos de píxeles del lienzo.
Aquí hay un JSFiddle cambia el color del logotipo de 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>