使用CSS3制作饼状旋转载入效果的实例
今天,要实现一个长任务等待提示效果。
然后设计师就把做好的gif效果图给我,就是狼蚁网站SEO优化这个
按照大众做法,我应该是把图片直接按图索骥,调调布局,然后早早回家抱老婆。
,我这个人,天生不安分守己。想到是用在客户端,客户端又是用的webkit内核,于是,立马决定使用CSS3来折腾一番。
外面的光环很好实现,360度转转转就OK. ,中间那个鸡蛋转转转的可不是好啃的骨头啊。人家师傅饼前一分钟,饼下十年功啊。
我生小辈想要习得这转饼的精髓,可得要好生琢磨一番啊!
如果您手头的是IE10+这类支持animation的现代浏览器,您可以狠狠地点击这里
截图是死的,demo是活的。建议点上面的地址去仔细对比CSS3实现和gif动画效果。
不难发现,这个gif尺寸又大,效果也不流畅,还烧性能。相比之下,立马被CSS3实现甩出了2条南京路。
CSS3效果更佳、性能更高、资源占用更少大家都认同了。关键是,这个大饼它是怎么转起来的?
略复杂。
蛋饼旋转技能传授
师父领进门修行在个人,听不懂我也没办法啦~~
我们肉眼看上去是一个鸡蛋被摊在了整个饼上,实际上,这只是个障眼法。
实际摊的鸡蛋,只有半个饼那么大。还有半个饼位置是长得像鸡蛋的假鸡蛋和长得像大饼的假大饼。显然这句话你听不懂,因为我自己都没听懂,哈哈~~所谓一图胜千言,示意图走起~
下图示意的就是鸡蛋饼上的鸡蛋从100%变小成0的过程。
1. 这是没有干扰的蛋饼,你看到的是半个假饼和半个假蛋。
2. 当我们煎饼动画转起的一瞬间,我们让假的饼子隐藏回家打酱油去。于是,从上面看,我们看到的就是满满一层的鸡蛋。
3. 真鸡蛋转起,你会发现,半个真鸡蛋,由于逆时针旋转,露出了点空(左侧上部)。
demo对应效果类似(浅色看成鸡蛋)
4. 当真鸡蛋旋转了180度(半圈)的时候,真假鸡蛋正好重合在了一起,于是就是看到的就是蛋饼上半面鸡蛋。
demo对应效果类似
demo对应效果类似
6. 一直旋转到360度,其完全被假的饼子遮盖,一点鸡蛋都看不到了。完成了从全部都0的动画过程。这就是蛋饼转转转的基本原理。
CSS3表示
可见,要实现我们想要的蛋饼效果,我们需要这些东西
圆形的蛋饼子 – 对应狼蚁网站SEO优化类名为ner元素
旋转的半面真鸡蛋 – 对应狼蚁网站SEO优化类名为sper的元素
不动的半面蛋饼子,前半程隐藏,后半程出现 – 对应狼蚁网站SEO优化类名为masker的元素
不动的半面假鸡蛋,前半程出现,后半程隐藏 – 对应狼蚁网站SEO优化类名为filler的元素
- <div class="ner">
- <div class="sper"></div>
- <div class="filler"></div>
- <div class="masker"></div>
- </div>
ner主要实现圆以及背景色;
sper主要实现半圆的360度逆时针旋转,其背景色有别于父元素的背景色;
filler半圆,定位在右侧,与旋转元素同样背景色;后面的180度隐藏;
masker半圆,定位在左侧,与大背景色色值相同;旋转前180度隐藏,之后显示遮盖;
其中,360度旋转CSS代码如下
- @keyframes sp {
- 0% { transform: rotate(360deg); }
- 100% { transform: rotate(0deg); }
- }
因为是逆时针,所以是从360deg到0deg.
前半程出现,后半程隐藏,可以借助animation step相关的timg function实现,代码如下
- @keyframes second-half-hide {
- 0% { opacity: 1; }
- 50%, 100% { opacity: 0; }
- }
后半程显示则是
- @keyframes second-half-show {
- 0% { opacity: 0; }
- 50%, 100% { opacity: 1; }
- }
于是,我们只要加个动画时间,以及无限执行就OK啦~~
- .sper { transform-orig: rightright center; animation: sp .8s fite lear; }
- .filler { animation: second-half-hide .8s steps(1, end) fite; }
- .masker { animation: second-half-show .8s steps(1, end) fite; }
其他细节都是定位什么的,很基础的知识,就不啰嗦啦~~
饼其实还没有做好
啊,捣鼓了这么久还没有结束啊?
没错。仔细查看gif动画,你会发现,蛋饼它是从全盘都0再到整个360度覆盖的。
而,上午捣鼓的动画只是从360度无死角覆盖到0覆盖。一旦覆盖结束,就又要走360度开始,不连贯,怎么破?
我是这么处理的
再覆盖一个蛋饼从0度到360度展示的动画。与一直捣鼓的动画前后半程分别展示就可以了。
于是,最终有如下HTML:
- <div class="ner">
- <div class="sper"></div>
- <div class="filler"></div>
- <div class="masker"></div>
- </div>
- <div class="ner2">
- <div class="sper"></div>
- <div class="filler"></div>
- <div class="masker"></div>
- </div>
ner和ner2也使用的前后半程隐藏的动画,动画时间正好是一个周期的2倍。
- .ner { opacity: 1; animation: second-half-hide 1.6s steps(1, end) fite; }
- .ner2 { opacity: 0; animation: second-half-show 1.6s steps(1, end) fite; }
于是,就有了完美的做蛋饼效果了。
网站设计
- 静宁会SEO的网站建设公司:全面提升您的网络影
- 提升在线业务的关键:选择最佳的丽水网站建设
- 浙江网站优化发展潜力如何
- 井研专业的网站建设公司:打造您的在线品牌
- 灵山SEO网站建设公司:提升您的在线业务表现
- 蒙城网站建设优化公司:提升您网站表现的理想
- 阳谷企业网站优化:提升线上业务力的关键
- 樟树专业的网站建设公司:打造您在线业务的坚
- 通河百度SEO排名的策略与技巧
- 重庆百度快照排名如何进行精准的客户引流
- 重庆百度快照排名
- 常宁便宜的建站公司:助您轻松打造在线业务
- 巫溪百度网站优化:提升网站曝光率与流量的关
- 湖北整站优化怎么做才能放大客户需求
- 闸北网站建设多少钱?全面解析与预算规划
- 辽宁企业网站优化怎么做电话营销