本篇文章給大家介紹一下巧用 CSS實現(xiàn)酷炫充電動畫效果的方法。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。
循序漸進,看看只使用 CSS ,可以鼓搗出什么樣的充電動畫效果。(學習視頻分享:css視頻教程)
畫個電池
當然,電池充電,首先得用 CSS 畫一個電池,這個不難,隨便整一個:
歐了,勉強就是它了。有了電池,那接下來直接充電吧。最最簡單的動畫,那應該是用色彩把整個電池灌滿即可。
方法很多,代碼也很簡單,直接看效果:
有內味了,如果要求不高,這個勉強也就能夠交差了。通過藍色漸變表示電量,通過色塊的位移動畫實現(xiàn)充電的動畫。但是總感覺少了點什么。
增加陰影及顏色的變化
如果要繼續(xù)優(yōu)化的話,需要添加點細節(jié)。
我們知道,低電量時,電量通常表示為紅色,高電量時表示為綠色。再給整個色塊添加點陰影的變化,呼吸的感覺,讓充電的效果看起來確實是在動。
知識點
到這里,其實只有一個知識點:
- 使用 filter: hue-rotate() 對漸變色彩進行色彩過渡變換動畫
我們無法對一個漸變色直接進行 animation ,這里通過濾鏡對色相進行調整,從而實現(xiàn)了漸變色的變換動畫。
上述例子完整的 Demo: CodePen Demo — Battery Animation One
添加波浪
ok,剛剛算一個小里程碑,接下來再進一步。電量的頂部為一條直線有點呆呆的感覺,這里我們進行改造一下,如果能將頂部直線,改為波浪滾動,效果會更為逼真一點。
改造之后的效果:
使用 CSS 實現(xiàn)這種波浪滾動效果,其實只是用了一種障眼法,具體的可以我早期寫的這篇文章:
純 CSS 實現(xiàn)波浪效果!
知識點
這里的一個知識點就是上述說的使用 CSS 實現(xiàn)簡易的波浪效果,通過障眼法實現(xiàn),看看圖就明白了:
上述例子完整的 Demo: CodePen Demo — Battery Animation Two
OK,到這,上述效果加上數(shù)字變化已經算是一個比較不錯的效果了。當然上面的效果看上去還是很 CSS 的,就是一眼看到就覺得用 CSS 是可以做到的。
使用強大的 CSS 濾鏡實現(xiàn)安卓充電動畫效果
那下面這個呢?
用安卓手機的同學肯定不陌生,這個是安卓手機在充電的時候的效果??吹竭@個我就很好奇,使用 CSS 能做到嗎?
經過一番嘗試,發(fā)現(xiàn)使用 CSS 也是可以很好的模擬這種動畫效果:
上述 Gif 錄制的效果圖是完全使用 CSS 模擬的效果。
上述例子完整的 Demo: HuaWei Battery Charging Animation
知識點
拆解一下知識點,最主要的其實是用到了 filter: contrast()
以及 filter: blur()
這兩個濾鏡,可以很好的實現(xiàn)這種融合效果。
單獨將兩個濾鏡拿出來,它們的作用分別是:
filter: blur()
: 給圖像設置高斯模糊效果。filter: contrast()
: 調整圖像的對比度。
但是,當他們“合體”的時候,產生了奇妙的融合現(xiàn)象。
先來看一個簡單的例子:
仔細看兩圓相交的過程,在邊與邊接觸的時候,會產生一種邊界融合的效果,通過對比度濾鏡把高斯模糊的模糊邊緣給干掉,利用高斯模糊實現(xiàn)融合效果。
當然,這種效果在之前的文章也多次提及過,更具體的,可以看看:
- CSS 火焰?不在話下
- 你所不知道的 CSS 濾鏡技巧與細節(jié)
顏色的變換
當然,這里也是可以加上顏色的變換,效果也很不錯:
上述例子完整的 Demo: HuaWei Battery Charging Animation
容易忽視的點
通過調節(jié) filter: blur()
及 filter: contrast()
屬性的值,動畫效果其實會有很大程度的變化,好的效果需要不斷的調試。當然,經驗在其中也是發(fā)揮了很重要的作用,說到底還是要多嘗試。
本文轉載自:https://juejin.cn/post/6844904029336649741
作者: ChokCoco