【CSS】グレースケールの画像をホバーで色を表示させる-(filterプロパティ)
data:image/s3,"s3://crabby-images/4e931/4e931f814eb3b285edb71ab2ca609fa0a2104172" alt=""
data:image/s3,"s3://crabby-images/033c8/033c883ba86f7d2724f77c4f4377b9f81f316d2d" alt=""
今回はfilterプロパティについて学んで行きましょう
filter:grayscale;
filter:grayscale;画像にfilter:grayscale(100%);を指定しておいて、ホバーすると色が表示されるような使われ方をよくします。
<div class="grid">
<div class="filter"><img src="img/01.jpg" alt=""></div>
<div class="filter"><img src="img/02.jpg" alt=""></div>
<div class="filter"><img src="img/03.jpg" alt=""></div>
<div class="filter"><img src="img/04.jpg" alt=""></div>
<div class="filter"><img src="img/05.jpg" alt=""></div>
<div class="filter"><img src="img/06.jpg" alt=""></div>
</div>
.grid {
margin: 0 auto;
display: grid;
width: 1520px;
grid-template-columns: 1fr 1fr 1fr;
gap: 10px;
}
.grid img {
filter: grayscale(100%);
}
.grid img:hover {
filter: grayscale(0);
}
初期値:none;
filter:grayscale(100%);でグレーになります。
data:image/s3,"s3://crabby-images/d673e/d673ec6945b31ca6490089fa929284bc1afce729" alt=""
data:image/s3,"s3://crabby-images/d696d/d696d12169fdb4c99b472993b768cb56a9d48133" alt=""
hoverしたときに filter: grayscale(0) を指定すると、元の色が表示されます。
その他のフィルター関数
filter: blur;
ぼかしを入れることができます。
%指定はできません。
data:image/s3,"s3://crabby-images/d673e/d673ec6945b31ca6490089fa929284bc1afce729" alt=""
data:image/s3,"s3://crabby-images/3054a/3054ad4235000a656399c6169805dd29b91b5b9b" alt=""
filter:brightness;
明るさを指定します。
filter:brightness(130%);ではより光ったような印象にすることができますね。
data:image/s3,"s3://crabby-images/18891/18891f032eefde45be53ddef4ef6d25d4d1495fc" alt=""
data:image/s3,"s3://crabby-images/d673e/d673ec6945b31ca6490089fa929284bc1afce729" alt=""
data:image/s3,"s3://crabby-images/90065/90065725fa6e6e14e103b4ae106de44077f665ba" alt=""
filter:contrast;
コントラストを調整します。
filter:contrast(150%);では明るい箇所と暗い箇所がよりはっきりします。
data:image/s3,"s3://crabby-images/176bb/176bb09368cb402fc7869f8d512aff94e9ded542" alt=""
data:image/s3,"s3://crabby-images/d673e/d673ec6945b31ca6490089fa929284bc1afce729" alt=""
data:image/s3,"s3://crabby-images/3320a/3320a2d0f49852c63bdb8d2f93d4b99f6b56030e" alt=""
filter:drop-shadow(x軸 y軸 ぼかし 色);
画像にドロップシャドウをかけます。
data:image/s3,"s3://crabby-images/d673e/d673ec6945b31ca6490089fa929284bc1afce729" alt=""
data:image/s3,"s3://crabby-images/037f0/037f0b80702583e0eb19f668e8a6de74b281ccfd" alt=""
filter:hue-rotate(角度);
色相環の回転をします。
data:image/s3,"s3://crabby-images/d673e/d673ec6945b31ca6490089fa929284bc1afce729" alt=""
data:image/s3,"s3://crabby-images/19e0a/19e0a98d990471bd2237ccc6f4c6117cf498e780" alt=""
180(deg)で180°回転した色になります。
CSSだけで色味を調節できて便利です。
data:image/s3,"s3://crabby-images/96c0d/96c0d602729138837859800c0638ee939cabe401" alt=""
data:image/s3,"s3://crabby-images/e1b8b/e1b8beb5e435c6c0ab000b458ffea98e41060234" alt=""
filter:invert;
階調を反転します。
data:image/s3,"s3://crabby-images/d673e/d673ec6945b31ca6490089fa929284bc1afce729" alt=""
data:image/s3,"s3://crabby-images/dd371/dd3712e3ffc43eff8deda146882c7af8ae858367" alt=""
filter:opacity;
不透明度を調節します。
filter:opacity(0);で非表示になります。
filter:opacity;もマウスオーバーで透明度を下げる表現がよく使われます。
data:image/s3,"s3://crabby-images/d673e/d673ec6945b31ca6490089fa929284bc1afce729" alt=""
data:image/s3,"s3://crabby-images/4f417/4f417c59cabf44930024e58b024bc7d8edca71b9" alt=""
filter:saturate;
鮮やかさの調節
data:image/s3,"s3://crabby-images/d673e/d673ec6945b31ca6490089fa929284bc1afce729" alt=""
data:image/s3,"s3://crabby-images/b64d8/b64d834033d7d4ae6126893e7d52737e9c34762c" alt=""
filter:sepia;
セピアになります。
雰囲気を出したい画像に良いですね。
data:image/s3,"s3://crabby-images/d673e/d673ec6945b31ca6490089fa929284bc1afce729" alt=""
data:image/s3,"s3://crabby-images/c4262/c42625808705d960847479e77e33ecfb0a1523df" alt=""
同じカテゴリの記事一覧へ
はじめての1冊におすすめ