首頁 >web前端 >css教學 >如何使用純CSS實現一個圓環旋轉錯覺的動畫效果(附源碼)

如何使用純CSS實現一個圓環旋轉錯覺的動畫效果(附源碼)

不言
不言原創
2018-09-05 09:55:173018瀏覽

這篇文章帶給大家的內容是關於如何使用純CSS實現一個圓環旋轉錯覺的動畫效果,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。

效果預覽

如何使用純CSS實現一個圓環旋轉錯覺的動畫效果(附源碼)

#原始碼下載

#https://github.com/comehop​​e/front-end-daily-challenges

程式碼解讀

定義dom,容器包含10 個<div> 子元素,每個<code><div> 子元素內還有一個<code><span></span> 子元素:

<figure>
    <div><span></span></div>
    <div><span></span></div>
    <div><span></span></div>
    <div><span></span></div>
    <div><span></span></div>
    <div><span></span></div>
    <div><span></span></div>
    <div><span></span></div>
    <div><span></span></div>
    <div><span></span></div>
</figure>

定義容器尺寸:

.container {
    width: 17em;
    height: 17em;
    font-size: 16px;
}

定義子元素的尺寸,和容器相同:

.container {
    position: relative;
}

.container div {
    position: absolute;
    width: inherit;
    height: inherit;
}

在子元素的正中畫一個黃色的小方塊:

.container div {
    display: flex;
    align-items: center;
    justify-content: center;
}

.container span {
    position: absolute;
    width: 1em;
    height: 1em;
    background-color: yellow;
}

增加讓小方塊左右移動的動畫效果,動畫時間還會在後面用到,所以定義成變數:

.container span {
    --duration: 2s;
    animation: move var(--duration) infinite;
}

@keyframes move {
    0%, 100% {
        left: calc(10% - 0.5em);
    }

    50% {
        left: calc(90% - 0.5em);
    }
}

用貝賽爾曲線調整動畫的時間函數,使小方塊看起來就像在左右兩側跳來跳去:

.container span {
    animation: move var(--duration) cubic-bezier(0.6, -0.3, 0.7, 0) infinite;
}

增加小方塊變形的動畫,使它看起來有下蹲起跳的擬人效果:

.container span {
    animation: 
        move var(--duration) cubic-bezier(0.6, -0.3, 0.7, 0) infinite,
        morph var(--duration) ease-in-out infinite;
}

@keyframes morph {
    0%, 50%, 100% {
        transform: scale(0.75, 1);
    }

    25%, 75% {
        transform: scale(1.5, 0.5);
    }
}

至此,完成了1 個方塊的動畫。接下來設定多個方塊的動畫效果。

為子元素定義CSS 下標變數:

.container div:nth-child(1) { --n: 1; }
.container div:nth-child(2) { --n: 2; }
.container div:nth-child(3) { --n: 3; }
.container div:nth-child(4) { --n: 4; }
.container div:nth-child(5) { --n: 5; }
.container div:nth-child(6) { --n: 6; }
.container div:nth-child(7) { --n: 7; }
.container div:nth-child(8) { --n: 8; }
.container div:nth-child(9) { --n: 9; }

旋轉子元素,使小方塊分佈均勻​​地在容器的四周,圍合成一個圓形:

.container p {
    transform: rotate(calc(var(--n) * 40deg));
}

當設定動畫延時,現在看起來就像是一群小方塊貼著一個圓的內邊線在旋轉了(但實際上沒有任何元素在做旋轉運動,大腦感覺到的旋轉是一種錯覺):

.container span {
    animation-delay: calc(var(--duration) / 9 * var(--n) * -1);
}

最後,為小方塊上色:

.container span {
    background-color: hsl(calc(var(--n) * 80deg), 100%, 70%);
}

大功告成!想了解更多css知識,可以去php中文網css教學欄位去學習一下。

相關推薦:

如何使用純CSS實現太陽和地球和月亮的運轉模型動畫

如何使用純CSS實現一個足球場的俯視圖(附原始碼)

以上是如何使用純CSS實現一個圓環旋轉錯覺的動畫效果(附源碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

php css dom github https
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
上一篇:css3製作陰影效果的方法詳解【程式碼範例】下一篇:css3製作陰影效果的方法詳解【程式碼範例】

相關文章

看更多