使用CSS3制作饼状旋转载入效果的实例


Posted in HTML / CSS onJune 23, 2015

今天,要实现一个长任务等待提示效果。

然后设计师就把做好的gif效果图给我,就是下面这个:
使用CSS3制作饼状旋转载入效果的实例

按照大众做法,我应该是把图片直接按图索骥,调调布局,然后早早回家抱老婆。

但是,我这个人,天生不安分守己。想到是用在客户端,客户端又是用的webkit内核,于是,立马决定使用CSS3来折腾一番。

外面的光环很好实现,360度转转转就OK. 但是,中间那个鸡蛋转转转的可不是好啃的骨头啊。人家师傅饼前一分钟,饼下十年功啊。

我生小辈想要习得这转饼的精髓,可得要好生琢磨一番啊!

如果您手头的是IE10+这类支持animation的现代浏览器,您可以狠狠地点击这里:CSS3饼状图loading旋转动画demo
使用CSS3制作饼状旋转载入效果的实例

截图是死的,demo是活的。建议点上面的地址去仔细对比CSS3实现和gif动画效果。

不难发现,这个gif尺寸又大,效果也不流畅,还烧性能。相比之下,立马被CSS3实现甩出了2条南京路。

CSS3效果更佳、性能更高、资源占用更少大家都认同了。关键是,这个大饼它是怎么转起来的?

略复杂。
蛋饼旋转技能传授

师父领进门修行在个人,听不懂我也没办法啦~~

我们肉眼看上去是一个鸡蛋被摊在了整个饼上,实际上,这只是个障眼法。

实际摊的鸡蛋,只有半个饼那么大。还有半个饼位置是长得像鸡蛋的假鸡蛋和长得像大饼的假大饼。显然这句话你听不懂,因为我自己都没听懂,哈哈~~所谓一图胜千言,示意图走起~

下图示意的就是鸡蛋饼上的鸡蛋从100%变小成0的过程。

1. 这是没有干扰的蛋饼,你看到的是半个假饼和半个假蛋。
使用CSS3制作饼状旋转载入效果的实例

2. 当我们煎饼动画转起的一瞬间,我们让假的饼子隐藏回家打酱油去。于是,从上面看,我们看到的就是满满一层的鸡蛋。
使用CSS3制作饼状旋转载入效果的实例

3. 真鸡蛋转起,你会发现,半个真鸡蛋,由于逆时针旋转,露出了点空(左侧上部)。
使用CSS3制作饼状旋转载入效果的实例

demo对应效果类似(浅色看成鸡蛋):
使用CSS3制作饼状旋转载入效果的实例

4. 当真鸡蛋旋转了180度(半圈)的时候,真假鸡蛋正好重合在了一起,于是就是看到的就是蛋饼上半面鸡蛋。
使用CSS3制作饼状旋转载入效果的实例

demo对应效果类似:
使用CSS3制作饼状旋转载入效果的实例

demo对应效果类似:
使用CSS3制作饼状旋转载入效果的实例

6. 一直旋转到360度,其完全被假的饼子遮盖,一点鸡蛋都看不到了。完成了从全部都0的动画过程。这就是蛋饼转转转的基本原理。
使用CSS3制作饼状旋转载入效果的实例

CSS3表示
可见,要实现我们想要的蛋饼效果,我们需要这些东西:

    圆形的蛋饼子 – 对应下面类名为inner元素
    旋转的半面真鸡蛋 – 对应下面类名为spiner的元素
    不动的半面蛋饼子,前半程隐藏,后半程出现 – 对应下面类名为masker的元素
    不动的半面假鸡蛋,前半程出现,后半程隐藏 – 对应下面类名为filler的元素

CSS Code复制内容到剪贴板
  1. <div class="inner">   
  2.     <div class="spiner"></div>   
  3.     <div class="filler"></div>   
  4.     <div class="masker"></div>   
  5. </div>  

    inner主要实现圆以及背景色;
    spiner主要实现半圆的360度逆时针旋转,其背景色有别于父元素的背景色;
    filler半圆,定位在右侧,与旋转元素同样背景色;后面的180度隐藏;
    masker半圆,定位在左侧,与大背景色色值相同;旋转前180度隐藏,之后显示遮盖;

其中,360度旋转CSS代码如下:

CSS Code复制内容到剪贴板
  1. @keyframes spin {   
  2.   0%   { transform: rotate(360deg); }   
  3.   100% { transform: rotate(0deg); }   
  4. }  

因为是逆时针,所以是从360deg到0deg.

前半程出现,后半程隐藏,可以借助animation step相关的timing function实现,代码如下:

CSS Code复制内容到剪贴板
  1. @keyframes second-half-hide {   
  2.   0%        { opacity: 1; }   
  3.   50%, 100% { opacity: 0; }   
  4. }  

后半程显示则是:

CSS Code复制内容到剪贴板
  1. @keyframes second-half-show {   
  2.   0%        { opacity: 0; }   
  3.   50%, 100% { opacity: 1; }   
  4. }  

于是,我们只要加个动画时间,以及无限执行就OK啦~~

CSS Code复制内容到剪贴板
  1. .spiner { transform-origin: rightright center; animation: spin .8s infinite linear; }   
  2. .filler { animation: second-half-hide .8s steps(1, end) infinite; }   
  3. .masker { animation: second-half-show .8s steps(1, end) infinite; }  

其他细节都是定位什么的,很基础的知识,就不??吕?~

饼其实还没有做好
啊,捣鼓了这么久还没有结束啊?

没错。仔细查看gif动画,你会发现,蛋饼它是从全盘都0再到整个360度覆盖的。

而,上午捣鼓的动画只是从360度无死角覆盖到0覆盖。一旦覆盖结束,就又要走360度开始,不连贯,怎么破?

我是这么处理的:
再覆盖一个蛋饼从0度到360度展示的动画。与一直捣鼓的动画前后半程分别展示就可以了。

于是,最终有如下HTML:

XML/HTML Code复制内容到剪贴板
  1. <div class="inner">  
  2.     <div class="spiner"></div>  
  3.     <div class="filler"></div>  
  4.     <div class="masker"></div>  
  5. </div>  
  6. <div class="inner2">  
  7.     <div class="spiner"></div>  
  8.     <div class="filler"></div>  
  9.     <div class="masker"></div>  
  10. </div>  

inner和inner2也使用的前后半程隐藏的动画,动画时间正好是一个周期的2倍。

CSS Code复制内容到剪贴板
  1. .inner { opacity: 1; animation: second-half-hide 1.6s steps(1, end) infinite; }   
  2. .inner2 { opacity: 0; animation: second-half-show 1.6s steps(1, end) infinite; }  

于是,就有了完美的做蛋饼效果了。

HTML / CSS 相关文章推荐
45个非常奇妙的CSS3 特性应用示例
Jan 01 HTML / CSS
基于CSS3实现的漂亮Menu菜单效果代码
Sep 10 HTML / CSS
利用CSS3实现的文字定时向上滚动
Aug 29 HTML / CSS
css3使用animation属性实现炫酷效果(推荐)
Feb 04 HTML / CSS
HTML5中使用postMessage实现Ajax跨域请求的方法
Apr 19 HTML / CSS
html5跨域通讯之postMessage的用法总结
Nov 07 HTML / CSS
使用canvas压缩图片上传的方法示例
Feb 07 HTML / CSS
Html+Css+Jquery实现左侧滑动拉伸导航菜单栏的示例代码
Mar 17 HTML / CSS
HTML5 HTMLCollection和NodeList的区别详解
Apr 29 HTML / CSS
关于flex 上下文中自动 margin的问题(完整例子)
May 20 HTML / CSS
html5表单的required属性使用
Jul 07 HTML / CSS
通过feDisplacementMap和feImage实现水波特效
Apr 24 HTML / CSS
利用CSS3实现圆角的outline效果的教程
Jun 05 #HTML / CSS
浅析与CSS3的loading动画加载相关的transition优化
May 18 #HTML / CSS
CSS+jQuery+PHP+MySQL实现的在线答题功能
Apr 25 #HTML / CSS
CSS+jQuery实现的在线答题功能
Apr 25 #HTML / CSS
纯CSS3制作漂亮带动画效果的主机价格表
Apr 25 #HTML / CSS
纯CSS实现右侧底部悬浮效果(悬浮QQ、微信、微博、邮箱等联系方式)
Apr 24 #HTML / CSS
网页切图的CSS和布局经验与要点
Apr 09 #HTML / CSS
You might like
Fatal error: Call to undefined function curl_init()解决方法
2010/04/09 PHP
PHP获取和操作配置文件php.ini的几个函数介绍
2013/06/24 PHP
CI框架装载器Loader.php源码分析
2014/11/04 PHP
php ucwords() 函数将字符串中每个单词的首字符转换为大写(实现代码)
2016/05/12 PHP
浅谈PHP正则中的捕获组与非捕获组
2016/07/18 PHP
iis6手工创建网站后无法运行php脚本的解决方法
2017/06/08 PHP
php实现微信公众平台发红包功能
2018/06/14 PHP
Laravel中为什么不使用blpop取队列详析
2018/08/01 PHP
PHP实现百度人脸识别
2019/05/06 PHP
TNC vs IO BO3 第二场2.13
2021/03/10 DOTA
JS 自定义带默认值的函数
2011/07/21 Javascript
原生js实现给指定元素的后面追加内容
2013/04/10 Javascript
如何正确使用javascript 来进行我们的程序开发
2014/06/23 Javascript
js通过iframe加载外部网页的实现代码
2015/04/05 Javascript
JavaScript通过使用onerror设置默认图像显示代替alt
2016/03/01 Javascript
一道优雅面试题分析js中fn()和return fn()的区别
2016/07/05 Javascript
JS中使用DOM来控制HTML元素
2016/07/31 Javascript
学习vue.js条件渲染
2016/12/03 Javascript
Bootstrap fileinput组件封装及使用详解
2017/03/10 Javascript
小程序实现录音上传功能
2019/11/22 Javascript
python数据结构链表之单向链表(实例讲解)
2017/07/25 Python
python获取酷狗音乐top500的下载地址 MP3格式
2018/04/17 Python
python实现数据导出到excel的示例--普通格式
2018/05/03 Python
详谈Python 窗体(tkinter)表格数据(Treeview)
2018/10/11 Python
python如何实现一个刷网页小程序
2018/11/27 Python
python使用yield压平嵌套字典的超简单方法
2019/11/02 Python
html2canvas生成的图片偏移不完整的解决方法
2020/05/19 HTML / CSS
养殖行业的创业计划书
2014/01/05 职场文书
工程招投标邀请书
2014/01/26 职场文书
大学生怎样写好自荐信
2014/02/25 职场文书
节约电力资源的建议书
2014/03/12 职场文书
驾驶员安全责任书
2014/07/22 职场文书
幼儿教师2014年度工作总结
2014/12/16 职场文书
房贷工资证明范本
2015/06/12 职场文书
关于Python中进度条的六个实用技巧分享
2022/04/05 Python
Win11 引入 Windows 365 云操作系统,适应疫情期间混合办公模式:启动时直接登录、模
2022/04/06 数码科技