Фильтр CSS: сделать цветное изображение прозрачным белым

У меня есть цветное изображение PNG с прозрачностью. Я хотел бы использовать фильтр CSS, чтобы сделать все изображение белым, но оставить прозрачность как есть. Это возможно в CSS?

70 голосов | спросил Pascal Klein 15 J0000006Europe/Moscow 2014, 00:40:58

2 ответа


0

Вы можете использовать

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>

Во-первых, brightness(0) делает все изображение черным, кроме прозрачных частей, которые остаются прозрачными.

Затем invert(1) делает черные части белыми.

ответил Oriol 15 J0000006Europe/Moscow 2014, 00:55:29
0

Насколько мне известно, к сожалению, не существует CSS-фильтра для окрашивания элемента (возможно, с использованием некоторой магии фильтра SVG, но я несколько незнаком с этим), и даже если это не так, фильтры в основном поддерживается только браузерами webkit.

С учетом вышесказанного вы все равно можете обойти это и использовать canvas для изменения своего изображения. По сути, вы можете нарисовать элемент изображения на холсте, а затем перебрать пиксели, изменив соответствующие значения RGBA на нужный вам цвет.

Однако полотна имеют некоторые ограничения. Самое главное, вы должны убедиться, что изображение src происходит из того же домена, что и страница. В противном случае браузер не позволит вам читать или изменять пиксельные данные холста.

Вот JSFiddle изменение цвета логотипа 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>
ответил Daniel Perván 15 J0000006Europe/Moscow 2014, 01:39:55

Похожие вопросы

Популярные теги

security × 330linux × 316macos × 2827 × 268performance × 244command-line × 241sql-server × 235joomla-3.x × 222java × 189c++ × 186windows × 180cisco × 168bash × 158c# × 142gmail × 139arduino-uno × 139javascript × 134ssh × 133seo × 132mysql × 132