CSS filter: make color image with transparency white

前端 未结 2 1996
花落未央
花落未央 2021-01-29 19:41

I have a colored png image with transparency. I would like to use css filter to make the whole image white but leave the transparency as it is. Is that possible in CSS?

相关标签:
2条回答
  • 2021-01-29 20:20

    You can use

    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>

    First, brightness(0) makes all image black, except transparent parts, which remain transparent.

    Then, invert(1) makes the black parts white.

    0 讨论(0)
  • 2021-01-29 20:33

    To my knowledge, there is sadly no CSS filter to colorise an element (perhaps with the use of some SVG filter magic, but I'm somewhat unfamiliar with that) and even if that wasn't the case, filters are basically only supported by webkit browsers.

    With that said, you could still work around this and use a canvas to modify your image. Basically, you can draw an image element onto a canvas and then loop through the pixels, modifying the respective RGBA values to the colour you want.

    However, canvases do come with some restrictions. Most importantly, you have to make sure that the image src comes from the same domain as the page. Otherwise the browser won't allow you to read or modify the pixel data of the canvas.

    Here's a JSFiddle changing the colour of the JSFiddle logo.

    //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>

    0 讨论(0)
提交回复
热议问题