WonderCSS

利用animation制作Loading动画实例

在刚刚学习了 CSS3超绚animation动画标签 后我们着手实践,学而时习之嘛!出于巨人肩膀的理论直接在网上找个成型的实例来分析,这也是我多年学习代码的途径。

由于目前支持CSS3新属性 animation 动画的只有高版本的浏览器,所以下面示例小于IE10无法看到:

看示例可分析出,动画是由多个(5个)圆点,由起点同时出发,按照各自不同的速度,先后回到终点完成一个循环。

HTML代码部分


<div id="container">
     <div id="spinner" class="active">
          <span id="ball_1" class="spinner_ball"></span>
          <span id="ball_2" class="spinner_ball"></span>
          <span id="ball_3" class="spinner_ball"></span>
          <span id="ball_4" class="spinner_ball"></span>
          <span id="ball_5" class="spinner_ball"></span>
     </div>
</div>

CSS代码部分


#container {
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	background-color:#174585;
}
#spinner.active {
	display: block;
}
#spinner {
	display: none;
	position: absolute;
	height: 60px;
	width: 60px;
	top: 40%;
	left: 48%;
	z-index: 1;
}
.spinner_ball {
	position: absolute;
	display: block;
	background-color: white;
	left: 24px;
	width: 4px;
	height: 4px;
	border-radius: 2px;
}
#ball_1 {
	-webkit-animation-timing-function: cubic-bezier( 0.7, 0.3, 0.7, 0.9);
	-webkit-animation-name: rotate; 
	-webkit-animation-duration: .6s; 
	-webkit-animation-iteration-count: infinite;
	-webkit-transform-origin: 6px 30px;
}
#ball_2 {
	-webkit-animation-timing-function: cubic-bezier( 0.6, 0.4, 0.6, 0.9);
	-webkit-animation-name: rotate; 
	-webkit-animation-duration: .6s; 
	-webkit-animation-iteration-count: infinite;
	-webkit-transform-origin: 6px 30px;
}
#ball_3 {
	-webkit-animation-timing-function: cubic-bezier( 0.5, 0.5, 0.5, 0.9);
	-webkit-animation-name: rotate; 
	-webkit-animation-duration: .6s; 
	-webkit-animation-iteration-count: infinite;
	-webkit-transform-origin: 6px 30px;
}
#ball_4 {
	-webkit-animation-timing-function: cubic-bezier( 0.4, 0.6, 0.4, 0.9);
	-webkit-animation-name: rotate; 
	-webkit-animation-duration: .6s; 
	-webkit-animation-iteration-count: infinite;
	-webkit-transform-origin: 6px 30px;
}
#ball_5 {
	-webkit-animation-timing-function: cubic-bezier( 0.3, 0.7, 0.3, 0.9);
	-webkit-animation-name: rotate; 
	-webkit-animation-duration: .6s; 
	-webkit-animation-iteration-count: infinite;
	-webkit-transform-origin: 6px 30px;
}
@-webkit-keyframes rotate {
  0% {
	-webkit-transform: rotate(0deg) scale(1);
  }
  100% { 
	-webkit-transform: rotate(360deg) scale(1); 
  }
}

下面我们来看看示例中的核心语句,以最后一个圆点的移动来看:


#ball_5 {
	-webkit-animation-timing-function: cubic-bezier( 0.3, 0.7, 0.3, 0.9);
        /*cubic-bezier允许你去自定义一个时间曲线,示例中以此区分不同圆点的移动频率*/
	-webkit-animation-name: rotate;
        /*定义动画名*/
	-webkit-animation-duration: .6s;
        /*动画持续时间*/
	-webkit-animation-iteration-count: infinite;
        /*循环次数,默认值为无限循环*/
	-webkit-transform-origin: 6px 30px;
        /*transform-origin允许您改变被转换元素的基点*/
}

By 于湛 发布于 2013.04.8 6,831 次浏览

利用animation制作Loading动画实例》上有2条评论

  1. YuZhan 文章作者

    经测试 animation 通过添加浏览器内核前缀不再是 -webkit 独有,除了IE6 7 8 9 外所有主流浏览器最新版都支持!

    回复
  2. HackersAnts

    没想到在牛哄哄的HTML5背后,还有CSS3这么一个狠角色……

    回复

发表评论

电子邮件地址不会被公开。 必填项已用*标注