使用純CSS實現(xiàn)一個圓環(huán)旋轉(zhuǎn)錯覺的動畫效果?這個問題可能是我們?nèi)粘W(xué)習(xí)或工作經(jīng)常見到的。希望通過這個問題能讓你收獲頗深。下面是小編給大家?guī)淼膮⒖純?nèi)容,讓我們一起來看看吧!
創(chuàng)新互聯(lián)建站長期為千余家客戶提供的網(wǎng)站建設(shè)服務(wù),團隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為吉安企業(yè)提供專業(yè)的成都網(wǎng)站設(shè)計、做網(wǎng)站,吉安網(wǎng)站改版等技術(shù)服務(wù)。擁有十載豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。效果預(yù)覽源代碼下載https://github.com/comehope/front-end-daily-challenges
代碼解讀定義 dom,容器中包含 10 個 定義容器尺寸: 定義子元素的尺寸,和容器相同: 在子元素的正中畫一個黃色的小方塊: 增加讓小方塊左右移動的動畫效果,動畫時長還會在后面用到,所以定義成變量: 用貝賽爾曲線調(diào)整動畫的時間函數(shù),使小方塊看起來就像在左右兩側(cè)跳來跳去: 增加小方塊變形的動畫,使它看起來有下蹲起跳的擬人效果: 至此,完成了 1 個方塊的動畫。接下來設(shè)置多個方塊的動畫效果。 為子元素定義 CSS 下標變量: 旋轉(zhuǎn)子元素,使小方塊分布均勻地在容器的四周,圍合成一個圓形: 設(shè)置動畫延時,現(xiàn)在看起來就像是一群小方塊貼著一個圓的內(nèi)邊線在旋轉(zhuǎn)了(但實際上沒有任何元素在做旋轉(zhuǎn)運動,大腦感覺到的旋轉(zhuǎn)是一種錯覺): 最后,為小方塊上色: 感謝各位的閱讀!看完上述內(nèi)容,你們對使用純CSS實現(xiàn)一個圓環(huán)旋轉(zhuǎn)錯覺的動畫效果大概了解了嗎?希望文章內(nèi)容對大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站制作公司行業(yè)資訊頻道。子元素:
.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);
}
}
.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實現(xiàn)一個圓環(huán)旋轉(zhuǎn)錯覺的動畫效果-創(chuàng)新互聯(lián)
轉(zhuǎn)載來源:http://weahome.cn/article/dccpeg.html