建站学习网,专业提供各类建站教程,网页素材,SEO资讯等建站资源!

网站模板_网站源码_网站素材_建站教程_建站学习网

当前位置:建站学习网 > DIV+CSS教程 > DIV CSS教程 >

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

更新时间:2017-01-07整理编辑:建站学习网阅读:0

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

  然后设计师就把做好的gif效果图给我,就是下面这个:

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

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

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

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

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

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

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

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

  略复杂。

  蛋饼旋转技能传授

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

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

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

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

  1. 这是没有干扰的蛋饼,你看到的是半个假饼和半个假蛋。

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

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

  demo对应效果类似(浅色看成鸡蛋):

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

  demo对应效果类似:

  demo对应效果类似:

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

 

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

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

本文网址:https://www.dedexuexi.com/divcss/jc/2067.html

本站部分文章搜集与网络,如有侵权请联系本站,转载请说明出处。

标签:技巧
收藏此文 赞一下!() 打赏本站

如本文对您有帮助,就请建站学习网抽根烟吧!

支付宝打赏
微信打赏
定义渐变边框给图片加阴影
« 上一篇2017年01月07日
CSS控制DIV绝对定位、相对定位的技巧
2017年01月07日下一篇 »
  • DIV CSS如何给文字字体添加下划线?
    0阅读
    在css中可以使用text-decoration属性或border-bottom属性来给文字添加下划线样式。下面本篇文章就来给大家介绍一下,希望对大家有所帮助。方法1:使用text-decoration属性设置css的text-decoration属性用于指定添加到文本的修饰,其underline属...
  • 纯CSS3实现带动画效果导航菜单无需js
    0阅读
    随着互联网的发展,网页能表现的东西越来越多。由最开始单纯的文字和链接构成的网页,到后来的表格布局,再到div+css模式,现在发展到了 html+css3。网页能表达的东西越来越多,css3兴起已经
  • CSS定义超链接四个状态的正确顺序L-V-H-A
    0阅读
    css定义超链接是要有先后顺序的。否则,在某些浏览器里面有可能会出现某个样式不起作用的bug。不能正确显示想要的效果。 CSS属性的排列顺序: L-V-H-A 。 L-V-H-A是link、visited、hover、active的简写
  • 在ie7下css居中样式text-align:center;偏左问题解决方法
    0阅读
    css样式text-align:center;在ie7下偏左问题,想必有很多朋友的遇到过吧,下面有个不错的方法,大家可以参考下,希望对大家有所帮助 复制代码 代码如下: body { text-align:center; } 用ie7打开是居左的。
  • 对div盒子模型使用心得总结
    0阅读
    相信每一个从事web开发的人对盒子模型都有一个特殊的理解吧,本文也有一个理解并附有示例代码,喜欢的朋友可以参考下 盒子模型的计算 外边距(margin)+边框(border)+内边距(padding)+内容(content
 
QQ在线咨询