透明度のある色付きのpng画像があります。 cssフィルターを使用して画像全体を白にしますが、透明度はそのままにします。 CSSでそれは可能ですか?
使用できます
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)
は黒い部分を白にします。
私の知る限り、悲しいことに、要素を色付けする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>