使用css實(shí)現(xiàn)android系統(tǒng)的loading加載動(dòng)畫(huà)
web常用的loading圖標(biāo)有2種, 一種是ios的"菊花", 一種是android的"環(huán)". 今天我們用svg實(shí)現(xiàn)android的"環(huán)"動(dòng)畫(huà), 下節(jié)課實(shí)現(xiàn)ios的"菊花".

注意 : gif幀數(shù)少的原因, 實(shí)際動(dòng)畫(huà)效果是很 平滑
的.
xml(svg)
<svg width="36" height="36" viewBox="0 0 50 50" class="a-loading-android">
<circle cx="25" cy="25" r="20" fill="none" stroke="currentColor" stroke-width="5"></circle>
</svg>
首先我們定義svg的畫(huà)布尺寸為 50x50 , 在瀏覽器中縮放為 36x36 顯示(這個(gè)36你可以根據(jù)實(shí)際需要調(diào)整), 定義環(huán)的圓心坐標(biāo)為 25,25 , 半徑為20 (算下 周長(zhǎng)大概為125 , 后面會(huì)用到), 顏色為 currentColor 獲取父元素的color屬性的值, 環(huán)的寬度為5像素, 看下在沒(méi)寫css前的效果:

scss
.a-loading {
&-android {
animation: rotate 2s linear infinite;
transform-origin: center center;
>circle {
display: inline-block;
animation: dash 1500ms ease-in-out infinite;
stroke-linecap: round; // 端點(diǎn)是圓形
color: currentColor;
}
@keyframes rotate {
100% {
transform: rotate(360deg);
}
}
@keyframes dash {
0% {
stroke-dasharray: 1, 200;
}
50% {
stroke-dasharray: 100, 200;
stroke-dashoffset: -45;
}
100% {
stroke-dasharray: 100, 200;
stroke-dashoffset: -124;
}
}
}
}
stroke-dasharray
先解釋 stroke-dasharray , 他是用來(lái)定義虛線的, 比如 stroke-dasharray="50, 20" 表示實(shí)線部分為50, 間隙20的虛線:

試想一下, 如果環(huán)也用虛線表示, 并且讓 單位實(shí)線 部分的長(zhǎng)度在環(huán)的周長(zhǎng)范圍內(nèi)變化,這不就實(shí)現(xiàn)了(半環(huán)/滿環(huán)等形態(tài)), 下面分別是 stroke-dasharray 的值為 25, 200 / 50, 200 / 100, 200
:

注意 : 這里的 200
是隨意定義的, 表示虛線的間隙, 只要值大于環(huán)的周長(zhǎng)即可.
stroke-dashoffset
偏移, 值為正數(shù)的時(shí)候, 虛線逆時(shí)針回退, 負(fù)數(shù)順時(shí)針前進(jìn)(左圖的stroke-dashoffset:0, 環(huán)的起點(diǎn)在3點(diǎn)方向, 右圖設(shè)置為-10以后, 環(huán)的起點(diǎn)被順時(shí)針偏移了一段距離):

因?yàn)閯?dòng)畫(huà)中, 環(huán)在增加長(zhǎng)度的同時(shí) 尾部在收縮長(zhǎng)度 , 所以需要配合 stroke-dashoffset
實(shí)現(xiàn).
動(dòng)畫(huà)的3個(gè)關(guān)鍵時(shí)刻

**0%**的時(shí)刻
讓圓環(huán)只呈現(xiàn)一個(gè)點(diǎn), 為了讓循環(huán)一周后動(dòng)畫(huà)不突兀(你可以改成0對(duì)比下效果).
**50%**的時(shí)刻
為了讓圓環(huán)呈現(xiàn)80%的環(huán), 所以設(shè)置實(shí)線部分長(zhǎng)度為100(125*0.8, 125是周長(zhǎng)): stroke-dasharray: 100, 200; , 同時(shí)尾部在收縮, 所以設(shè)置 stroke-dashoffset: -45; .
**100%**的時(shí)刻
回到一個(gè)點(diǎn)的狀態(tài), 和0%狀態(tài)一致, 這樣動(dòng)畫(huà)循環(huán)起來(lái)不突兀, 但是從50%到100%的動(dòng)畫(huà)只是"尾部收縮", 所以我們用 stroke-dashoffset:-124 實(shí)現(xiàn), 125-124=1 正好是一個(gè)像素, 好了動(dòng)畫(huà)到此就實(shí)現(xiàn)完畢了.
整體旋轉(zhuǎn)
為了和安卓系統(tǒng)的動(dòng)畫(huà)一致, 讓整體也進(jìn)行旋轉(zhuǎn). 這里代碼比較簡(jiǎn)單不贅述.
animation屬性的擴(kuò)展
如果大家仔細(xì)看過(guò)css的 animation 的文檔, 會(huì)發(fā)現(xiàn) animation 可以同時(shí)支持多個(gè)過(guò)度動(dòng)畫(huà), 比如 animation: color 6s ease-in-out infinite, dash 1.5s ease-in-out infinite; , 用","分割多個(gè)動(dòng)畫(huà).
所以我們其實(shí)還可以對(duì)上面的動(dòng)畫(huà)進(jìn)行擴(kuò)展, 比如 旋轉(zhuǎn)的同時(shí)還有顏色變化 :

&-android {
animation: rotate 2s linear infinite;
transform-origin: center center;
>circle {
display: inline-block;
// 增加顏色變化的代碼
animation: color 6s ease-in-out infinite, dash 1.5s ease-in-out infinite;
stroke-linecap: round;
color: currentColor;
}
@keyframes rotate {
100% {
transform: rotate(360deg);
}
}
@keyframes dash {
0% {
stroke-dasharray: 1, 200;
}
50% {
stroke-dasharray: 100, 200;
stroke-dashoffset: -45;
}
100% {
stroke-dasharray: 100, 200;
stroke-dashoffset: -124;
}
}
@keyframes color {
0%,
100% {
stroke: #6b5c5b;
}
40% {
stroke: #0057e7;
}
66% {
stroke: #008744;
}
80%,
90% {
stroke: #ffa700;
}
}
}
本文代碼參考 iview , 一個(gè)vue框架.
總結(jié)
以上所述是小編給大家介紹的使用css實(shí)現(xiàn)android系統(tǒng)的loading加載動(dòng)畫(huà),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章

10種CSS3實(shí)現(xiàn)的loading動(dòng)畫(huà),挑一個(gè)走吧?
這篇文章主要介紹了10種CSS3實(shí)現(xiàn)的loading動(dòng)畫(huà),幫助大家更好的美化自身網(wǎng)頁(yè),完成需求,感興趣的朋友可以了解下2020-11-16
這篇文章主要介紹了CSS3制作3D立方體loading特效的示例,幫助大家更好的理解和使用CSS3特效,美化自身網(wǎng)頁(yè),感興趣的朋友可以了解下2020-11-09
CSS3實(shí)現(xiàn)漸變的loading加載進(jìn)度條特效代碼
css3 keyframes制作創(chuàng)意有趣的進(jìn)度條漸變加載動(dòng)畫(huà),loading進(jìn)度條動(dòng)畫(huà)特效,非常不錯(cuò),喜歡的朋友快來(lái)下載吧2020-10-21
CSS loading效果之 吃豆人的實(shí)現(xiàn)
這篇文章主要介紹了CSS loading效果之 吃豆人的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)2019-09-09
CSS 實(shí)現(xiàn)各種 Loading 效果附帶解析過(guò)程
這篇文章主要介紹了CSS 實(shí)現(xiàn)各種 Loading 效果附帶解析過(guò)程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-19




