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

所属分类: 网页制作 / CSS 阅读数: 719
收藏 0 赞 0 分享

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

然后设计师就把做好的gif效果图给我,就是下面这个:
2015623154443151.gif (86×86)

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

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

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

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

如果您手头的是IE10+这类支持animation的现代浏览器,您可以狠狠地点击这里:CSS3饼状图loading旋转动画demo
2015623154506455.png (232×310)

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

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

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

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

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

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

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

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

1. 这是没有干扰的蛋饼,你看到的是半个假饼和半个假蛋。
2015623154531334.png (454×340)

2. 当我们煎饼动画转起的一瞬间,我们让假的饼子隐藏回家打酱油去。于是,从上面看,我们看到的就是满满一层的鸡蛋。
2015623154552781.png (454×340)

3. 真鸡蛋转起,你会发现,半个真鸡蛋,由于逆时针旋转,露出了点空(左侧上部)。
2015623154614997.png (454×340)

demo对应效果类似(浅色看成鸡蛋):
2015623154630843.png (454×340)

4. 当真鸡蛋旋转了180度(半圈)的时候,真假鸡蛋正好重合在了一起,于是就是看到的就是蛋饼上半面鸡蛋。
2015623154649674.png (70×67)

demo对应效果类似:
2015623154708939.png (454×340)

demo对应效果类似:
2015623154724898.png (69×65)

6. 一直旋转到360度,其完全被假的饼子遮盖,一点鸡蛋都看不到了。完成了从全部都0的动画过程。这就是蛋饼转转转的基本原理。
2015623154742376.png (454×340)

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; }  

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

更多精彩内容其他人还在看

Opera中国的WEB标准课程

网页制作Webjx文章简介:在这篇文章里,我要向大家介绍我和其他很多人花费数月时间开发的一个课程——Web标准课程,该课程旨在向大家提供Web设计和开发的坚实基础,无论读者是谁,此教程完全免费、可访问,并且不需要预备知识。当然,我主要还
收藏 0 赞 0 分享

CSS样式表渐进增强的基本概念

网页制作Webjx文章简介:如果你挠着头想弄清楚优雅降级和渐进增强的区别,我告诉你,这是视角问题。优雅降级和渐进增强都考虑网站在各种设备的各种浏览器上如何良好运转。两者区别的关键在于它们各自关注的焦点,以及这种关注对工作流程的影响
收藏 0 赞 0 分享

简单介绍Web Developer插件制作网页

网页制作Webjx文章简介:Firefox浏览器是一个良好支持W3C标准的开放源代码的浏览器,拥有Linux/Windows/Mac版本。因为Firefox浏览器良好支持W3C标准,所以使用Firefox来调试网页是非常好的。 Firefox浏览器是
收藏 0 赞 0 分享

CSS布局带来的巨大影响:CSS display属性值

网页制作Webjx文章简介:网页元素应用上那些与表格相关的display属性值后,能够模仿出与表格相同的特性。我将会在该文中给大家演示这种方法给CSS布局带来的巨大影响。 应原书编辑要求,先在文章顶部给出链接:《Everything You
收藏 0 赞 0 分享

用div css模拟表格对角线

这只是探讨一种CSS模拟表格对角线的用法,实际在工作中可能觉得这样做有点小题大作,这不是本主题讨论的重点。如果对此深以为然的朋友,请一笑过之 首先声明: 这只是探讨一种CSS模拟表格对角线的
收藏 0 赞 0 分享

IE Firefox在css中的差别 (部分)

1、单位问题 问题:任何距离的数值ie可以不加单位,ff必须要求写单位(0除外) 解决:写全单位如padding:0px; 2、水平居中 问题:div里的内容,ie默认为center,而ff默认left 解决:mairgin:0px auto; 3、高度问题
收藏 0 赞 0 分享

不用js可以实现信息提示效果

[code] <style> body { font:verdena; font-size:14px; color:#000 } h1{ font:verdena; font-size:22px; color:#000 } h2{ font:verdena;
收藏 0 赞 0 分享

CSS解决未知高度的垂直水平居中自适应问题

今天有人问起,晚上试着写出来,供参考; 以下代码兼容主流浏览器IE6、IE7、Firefox、Opera。 从最简单的开始………… 一、如何让一个DIV水平居中? 这个简单不作过多说明! [code] <st
收藏 0 赞 0 分享

CSS cursor 属性 -- 鼠标指针样式效果

取值: [ [<uri> ,]* [ auto | crosshair | default | pointer | move | e-resize | ne-resize | nw-resize | n-resize | se-resize | sw-resize |
收藏 0 赞 0 分享

css 简单区别ie6,ie7,firefox的写法

同一样式里可以这样 [code] margin:17px; FF +margin:17px; IE6 IE7 _margin:17px; IE6 [/code] 按这个顺序,刚好区分开三个浏览器
收藏 0 赞 0 分享
查看更多