Rumah > hujung hadapan web > tutorial css > 如何使用纯CSS实现一个圆环旋转错觉的动画效果(附源码)

如何使用纯CSS实现一个圆环旋转错觉的动画效果(附源码)

不言
Lepaskan: 2018-09-05 09:55:17
asal
3149 orang telah melayarinya

本篇文章给大家带来的内容是关于如何使用纯CSS实现一个圆环旋转错觉的动画效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

效果预览

4212784137-5b8f1a308ea34_articlex.gif

源代码下载

https://github.com/comehope/front-end-daily-challenges

代码解读

定义 dom,容器中包含 10 个 <div> 子元素,每个 <div> 子元素内还有一个 <span> 子元素:

<figure class="container">
    <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>
Salin selepas log masuk

定义容器尺寸:

.container {
    width: 17em;
    height: 17em;
    font-size: 16px;
}
Salin selepas log masuk

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

.container {
    position: relative;
}

.container div {
    position: absolute;
    width: inherit;
    height: inherit;
}
Salin selepas log masuk

在子元素的正中画一个黄色的小方块:

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

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

增加让小方块左右移动的动画效果,动画时长还会在后面用到,所以定义成变量:

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

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

    50% {
        left: calc(90% - 0.5em);
    }
}
Salin selepas log masuk

用贝赛尔曲线调整动画的时间函数,使小方块看起来就像在左右两侧跳来跳去:

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

增加小方块变形的动画,使它看起来有下蹲起跳的拟人效果:

.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);
    }
}
Salin selepas log masuk

至此,完成了 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; }
Salin selepas log masuk

旋转子元素,使小方块分布均匀地在容器的四周,围合成一个圆形:

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

设置动画延时,现在看起来就像是一群小方块贴着一个圆的内边线在旋转了(但实际上没有任何元素在做旋转运动,大脑感觉到的旋转是一种错觉):

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

最后,为小方块上色:

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

大功告成!想要了解更多css知识,可以去php中文网css教程栏目去学习一下。

相关推荐:

如何使用纯CSS实现太阳和地球和月亮的运转模型动画

如何使用纯CSS实现一个足球场的俯视图(附源码)

Atas ialah kandungan terperinci 如何使用纯CSS实现一个圆环旋转错觉的动画效果(附源码). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan