para oscurecer opaco opacidad img imagen fondo filtros filtro decolorar color cambiar agregar css css-filters

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>