html怎么让方块自动旋转,如何使用纯CSS实现一个圆环旋转错觉的动画效果(附源码)...

5268f80b9b1e01f982625ef6fac83ca1.png

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

效果预览

d0a512405c5359ad9bf6d6ab2c8fd9c2.gif

源代码下载

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

代码解读

定义 dom,容器中包含 10 个

子元素,每个
子元素内还有一个 子元素:

定义容器尺寸:.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知识,可以去Gxl网css教程栏目去学习一下。

相关推荐:

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

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/257880.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

同志亦凡人第五季/全集BQueer As Folk 5迅雷下载

同志亦凡人 第五季 Queer as Folk Season 5 (2005) 本季看点:这是一群生活在匹兹堡男人和男人,女人和女人的故事。在他们的王国里有各色人物。王国的国王Brian(葛尔?哈罗德 Gale Harold 饰),只追求性不问爱&#xff1…

2016,请不要在公司混日子!

1、无论为谁打工,要为自己学东西,客观上为公司创造价值。 我自己当年,无论我在方正给国内企业工作,还是我在雅虎给外国人工作,我都跟别人最大的不一样,我从来不觉得我在给他们打工,我真的可能是…

数据库作业[定时执行任务]的创建

--每月执行的作业 exec p_createjob jobnamemm,sqlselect * from syscolumns,freqtypemonth --每周执行的作业 exec p_createjob jobnameww,sqlselect * from syscolumns,freqtypeweek --每日执行的作业 exec p_createjob jobnamea,sqlselect * from syscolumns --每日执行的作…

《算法之道》精华 经典算法部分

《算法之道》精华 经典算法部分 本书作者邹恒明,作者另有一本书《数据结构之弦》,以及《操作系统之哲学原理》都是非常好的书这本书能够算得上是深入浅出,文笔非常好。作者加入了非常多自己的思考本文包含经典算法部分第十章 排序与次序 插入…

学生社团网站html,学生社团活动平台的设计与实现.docx

PAGE 67学生社团活动平台的设计与实现摘 要本系统立足于实现社团活动申请与审批、资源申请与审批等工作,面向高校中所有的社团,建立一个使用便捷、可靠的社团活动平台,从而更方便地进行社团活动的申请、社团资源的申请及相应审批,…

tornado 学习笔记17 HTTPServerRequest分析

代表Http请求。 所有的属性都是字符串型。 17.1 属性 (1) method:请求方法类型,比如”GET”、”POST” (2) uri: 请求的uri (3) path:请求路径,作为uri的一部分。 (4) query:查询字符串:作为uri的一部分。 (5) version&#xff1a…

Android 动画效果及Interpolator和AnimationListener的使用

转载http://www.itzhai.com/android-animation-used-to-achieve-control-of-animation-effects-and-use-of-interpolator-and-animationlistener.htmlandroid:interpolator可能有很多人不理解它的用法,文档里说的也不太清楚,其实很简单,看下面…

html怎么使图片无法另存为,如何禁止图片另存为?禁止网页另存为到本地的方法...

在很多企事业单位,处于商业机密保护的需要,常常需要禁止一些文件格式的“另存为”功能,防止通过“另存为”将文件另行保存,据为己有的目的;尤其是在局域网中访问服务器共享文件的时候,常常需要禁止将共享文…

正益工场为京西创客工场输送双创“软”实力

12月30日,中关村门头沟科技园“京西创客工场”正式揭牌,这里将成为京西“生态科创”的聚集地。正益工场作为唯一入驻的“移动互联网”双创生态平台,将为双创输送“移动技术移动模式”等软实力。北京市副市长隋振江、市政协、中关村管委会等领…

【动态规划】【线段树】 Codeforces Round #426 (Div. 1) B. The Bakery

给你一个序列,让你划分成K段,每段的价值是其内部权值的种类数,让你最大化所有段的价值之和。 裸dp f(i,j)max{f(k,j-1)w(k1,i)}&#…

几种服务器端IO模型的简单介绍及实现(转载)

作者:阿凡卢 出处:http://www.cnblogs.com/luxiaoxun/服务器端几种模型: 1、阻塞式模型(blocking IO) 我们第一次接触到的网络编程都是从 listen()、accpet()、send()、recv() 等接口开始的。使用这些接口可以很方便的…

html细边框表格代码,html中表格细边框的四种实现及其比较.doc

html中表格细边框的四种实现及其比较?html中表格细边框的四种实现及其比较第一种使用css!--- 华丽的分隔线。。 -- .box ?border-top-width: 1px;?border-right-width: 0px;?border-bottom-width: 0px;?border-left-width: 1px;?border-top-style: solid;?border-right-…

margin 等高布局

<div id"main"><div id"left">我是左边的内容的啦啦啦啦。。。。<br> 我是左边的内容的啦啦啦啦。。。。<br> 我是左边的内容的啦啦啦啦。。。。<br> 我是左边的内容的啦啦啦啦。。。。<br> 我是左边的内容的啦啦啦啦…

c、c++---linux上的GetTickCount函数

http://blog.csdn.net/guang11cheng/article/details/6865992 http://wenda.so.com/q/1378766306062794

C#判断一个类中有无指定名称的方法

C#中可以通过反射分析元数据来解决这个问题&#xff0c;示例代码如下&#xff1a;12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849using System;using System.Reflection;namespace Hello{class Program{static void Main(string[…

2021年高考成绩查询襄阳状元,大胆猜测一下,2021年高考,湖北省文理状元会花落谁家?...

随着2021年高考的逼近&#xff0c;考生进入紧张有序的复习中&#xff0c;家长也在为孩子筹谋着哪所学校更适合&#xff0c;作为吃瓜群众的我们&#xff0c;可能更关注今年湖北省的文理科状元会花落谁家&#xff0c;要知道&#xff0c;一所学校如果可以出现一名高考状元&#xf…

为什么写Java程序需要接口

为什么写Java程序需要接口 我之所以以这个作为标题&#xff0c;并不是为了玩噱头&#xff0c;讲一些似是而非的空话&#xff0c;还是以探索加发现&#xff0c; 追本溯源的讲解一下为什么Java需要接口&#xff0c;怎么理解&#xff0c;怎么用它。 首先接口并不是Java才有的&…

《领域特定语言》一1.5使用代码生成

1.5使用代码生成 在迄今为止的讨论中&#xff0c;要处理DSL&#xff0c;组装“语义模型”&#xff08;第11章&#xff09;&#xff0c;然后执行语义模型&#xff0c;提供我们希望从控制器得到的行为。在语言圈子里&#xff0c;这种方式称为解释&#xff08;interpretation&…

SVG 基础图形

SVG 基础图形 SVG包含了以下的基础图形元素&#xff1a; 矩形&#xff08;包括可选的圆角&#xff09;&#xff0c;使用<rect>元素创建圆形&#xff0c;使用<circle>元素创建椭圆形&#xff0c;使用<ellipse>元素创建直线&#xff0c;使用<line>元素创…

枣庄三中高考2021成绩查询,2021枣庄中考成绩查询系统入口

2021枣庄中考成绩查询系统入口2021-05-20 19:11:35文/王佳慧2021年&#xff0c;枣庄的中考时间快到了&#xff0c;本文分享了枣庄中考成绩查询入口&#xff0c;系统开通后考生可登陆查询成绩。枣庄中考成绩查询入口志愿填报须知1.录取标准&#xff1a;提前批、第一批、第三批学…