【CSS】backdrop-filterでアニメーションを作ってみる
記事更新日:2022-02-05
data:image/s3,"s3://crabby-images/31e36/31e369c9bcb7b93bb47f37ebc9ae3492a4c291ad" alt="サムネイル"
data:image/s3,"s3://crabby-images/85a41/85a414829f7263801c928168a688963f4d14fdad" alt=""
filter と backdrop-filter って何が違うの?
backdrop( 背景幕)のフィルター
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
backdrop-filter: blur()は、「背後(back)」
filter:blur()は、「前面」
例)aタグにbackdrop-filter: blur()をかけた場合
data:image/s3,"s3://crabby-images/4af40/4af40db1a0daf5cd89591f53ed256f3b859a0748" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
aタグの背景がボケてて、汽車の通り道みたいな雰囲気になってる。
例)aタグに filter: blur()をかけた場合
data:image/s3,"s3://crabby-images/bf5f4/bf5f4e0f05da8328c766a42c514a41b67987836a" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
文字も一緒にボケちゃってるし、背景に何もない。
【 Point 】
使う場所によって、filter か backdrop-filter かで結果が少し違う
疑似要素を使ってボカしてみる
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
まずは backdrop-filterでボカシを入れてみよう。
疑似要素を使うとキレイにできる。
ここをクリックしてコードを見る
.item {
position: relative;
display: flex;
width: 100%;
height: 100%;
background: url(画像パス);
background-repeat: no-repeat;
background-size: cover;
background-position: center;
transition: filter 1s ease;
&::after {
position: absolute;
content: '';
top: 0;
left: 0;
width: 100%;
height: 100%;
backdrop-filter: blur(10px);
z-index: 1;
}
}
data:image/s3,"s3://crabby-images/2a3fb/2a3fb91fa51721155b4db7c47748096c949eab2a" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
きれいにボケてる。
左半分だけボカす
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
幅のサイズを50% にすれば半分になるよ。
ここをクリックしてコードを見る
.item {
〜
&::after {
position: absolute;
content: '';
top: 0;
left: 0;
width: 50%;
height: 100%;
backdrop-filter: blur(10px);
z-index: 1;
}
}
data:image/s3,"s3://crabby-images/3416c/3416ca4e58302c55be6b3fbb5a5d42676f97fc5e" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
左側に文字を入れたくなる。
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
ホバーエフェクトにしてもよさそう。
ここをクリックしてコードを見る
.item {
〜
&::after {
position: absolute;
content: '';
top: 0;
left: 0;
width: 50%;
height: 100%;
backdrop-filter: blur(10px);
transform: translateX(-100%);
z-index: 1;
&:hover {
&::after {
animation: transform-anim .5s forwards;
}
}
}
}
@keyframes transform-anim {
100% {
transform: translateX(0);
}
}
data:image/s3,"s3://crabby-images/dec20/dec20b9def148f030119e303cacca23ee6567c66" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
サイドバーにも使えそう。
下半分をボカす
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
上下だから、高さを50%にすればいいよ。
ここをクリックしてコードを見る
.item {
〜
&::after {
position: absolute;
content: '';
bottom: 0;
left: 0;
width: 100%;
height: 50%;
backdrop-filter: blur(10px);
z-index: 1;
}
}
data:image/s3,"s3://crabby-images/eb288/eb2881d738fc6abd68e06dbf1b5f26491335661b" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
カード型でよくありそう。
疑似要素の before と after で効果を変える
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
それぞれ違うフィルターにすることもできるよ。
ここをクリックしてコードを見る
.item {
〜
&::before,
&::after {
position: absolute;
content: '';
left: 0;
width: 100%;
height: 50%;
z-index: 1;
}
&::before {
top: 0;
backdrop-filter: grayscale(1);
}
&::after {
bottom: 0;
backdrop-filter: blur(10px);
}
}
data:image/s3,"s3://crabby-images/13988/13988c4f0276a70d2f6cb963a9f85644a1035022" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
1つのタグで、2つのフィルターが使えるんだね。
divタグを増やせば、複数のフィルターが使える
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
divタグを作って、4分割にしてみたよ。
ここをクリックしてコードを見る
<div class="item">
<div class="filter"></div>
</div>
.item {
〜
&::before,
&::after,
.filter::before,
.filter::after {
position: absolute;
content: '';
top: 0;
width: 25%;
height: 100%;
z-index: 1;
}
&::before {
left: 0;
backdrop-filter: hue-rotate(20deg);
}
&::after {
left: 25%;
backdrop-filter: hue-rotate(60deg);
}
.filter {
&::before {
left: 50%;
backdrop-filter: sepia(1);
}
&::after {
left: 75%;
backdrop-filter: hue-rotate(100deg);
}
}
}
data:image/s3,"s3://crabby-images/4760f/4760f471cbbb012bef255fcc29f8b987e5731ce8" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
しましま模様になった。
アニメーションを追加
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
4分割のままアニメーションにするのも面白いよ。
ここをクリックしてコードを見る
.item {
〜
&::before,
&::after,
.filter::before,
.filter::after {
position: absolute;
content: '';
top: 0;
width: 25%;
height: 100%;
z-index: 1;
animation: anim 2s infinite alternate;
}
&::before {
left: 0;
backdrop-filter: hue-rotate(20deg);
}
&::after {
left: 25%;
backdrop-filter: hue-rotate(60deg);
}
.filter {
&::before {
left: 50%;
backdrop-filter: sepia(1);
}
&::after {
left: 75%;
backdrop-filter: hue-rotate(100deg);
}
}
}
@keyframes anim {
0% {
transform: translateX(-100%);
filter: hue-rotate(0);
}
100% {
transform: translateX(100%);
filter: hue-rotate(0);
}
}
data:image/s3,"s3://crabby-images/1b77c/1b77c886c377d6c524e964147f7ff5b1cfa70f6c" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
昔のブラウン管みたいな感じ。
1つだけでアニメーション
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
4分割じゃなくて、1つだけでもいいかもね。
ここをクリックしてコードを見る
.item {
〜
&::after {
position: absolute;
content: '';
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 1;
backdrop-filter: grayscale(1);
animation: anim 20s infinite ease-out;
}
}
@keyframes anim {
0% {
transform: translateX(-100%);
filter: hue-rotate(0);
}
100% {
transform: translateX(100%);
filter: hue-rotate(0);
}
}
data:image/s3,"s3://crabby-images/f57c2/f57c286213587a54340eacc728a167e7d14fa974" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
だんだんと色がなくなっていく。
上から下へのアニメーション
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
ボケのアニメーションにしてみよう。
ここをクリックしてコードを見る
.item {
〜
&::after {
position: absolute;
content: '';
top: 0;
left: 0;
width: 100%;
height: 50%;
z-index: 1;
animation: anim-2 10s infinite;
}
}
@keyframes anim {
0% {
transform: translateY(-100%);
filter: hue-rotate(0);
}
100% {
transform: translateY(100%);
filter: hue-rotate(0);
}
}
data:image/s3,"s3://crabby-images/0f2aa/0f2aafd12c299bd610f4fed652136a14192d4fbe" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
最初はボカシて隠しておきたいときに、いいね。
まとめ
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
gifだとキレイに見えないので、デモページ(https://tsukiusagi.biz/demo/backfilter/)も参考にしてね。
data:image/s3,"s3://crabby-images/3e033/3e033651d84f855fdeafa9a6c57031cc78a15b4a" alt=""
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
いろんな色効果を使ってみよう。
2022-02-05
編集後記:
この記事の内容がベストではないかもしれません。