css3:animate使用踩坑

http://www.cnblogs.com/guorui-gr/archive/2012/12/07/2807359.html

好久没更新blog,上次发文(11月8日)到现在刚好一个月,期间项目上的东西比较多,一时觉得时间比较紧,没来得及更新。这个星期总算是告一段落,补上几篇技术性的文章。好吧,第一篇是关于css3动画的使用。

  昨天突然看到jing.fm(这个音乐网站非常不错,很多效果我都很喜欢,如果你有兴趣,可以去围观下)上音乐播放时,专辑的转动效果很不错,所以准备自己动手写下,以备后用。结果第一次使用animate就遇到了坑爹的事情,特吐槽下。

  一、最终的效果  

  

  如上图所示,最终是想让这个专辑的图片转动起来,模拟出唱片播放的效果(你可以去jing.fm上看看真实的效果,很赞,现在很多音乐网站都添加了这个效果)。

  二、结构代码  

复制代码
 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset='utf-8'>
 5         <title>音乐专辑播放模拟</title>
 6         <link rel="stylesheet" type="text/css" href="css/style.css">
 7     </head>
 8     <body>
 9         <div id="bd">
10             <div id="musicBox">
11                 <div class="cover rotateCD"></div>
12                 <div class="mask"></div>
13             </div>
14         </div>
15     </body>
16 </html>
复制代码

  从上面的代码可以看出,由于是使用css3强大的动画效果,所以我的结构定义的非常简单(在符合语义的前提下),同时没有引用到javascript脚本文件。

  musicBox来限定外围框的大小,内部的cover用来显示专辑封面图片,这个图片是下图左边图片这样的,四四方方,不是圆形,所以我在后面做了个mask的div,它不做其他事情,只是用来容纳一个遮罩(下图右边图片),盖住图片圆形之外的部分。

      

  三、css3样式表

  

复制代码
 1 @charset utf-8;
 2 
 3 /* common: rotateCD */
 4 @-webkit-keyframes myrotate{
 5     0%{
 6         -webkit-transform : rotate(0deg);
 7     }    
 8     100%{
 9         -webkit-transform : rotate(360deg);
10     }
11 }
12 @-moz-keyframes myrotate{
13     0%{
14         -moz-transform : rotate(0deg);
15     }
16     100%{
17         -moz-transform : rotate(360deg);
18     }
19 }
20 @-ms-keyframes myrotate{
21     0%{
22         -ms-transform : rotate(0deg);
23     }
24     100%{
25         -ms-transform : rotate(360deg);
26     }
27 }
28 @-o-keyframes myrotate{
29     0%{
30         -o-transform : rotate(0deg);
31     }
32     100%{
33         -o-transform : rotate(360deg);
34     }
35 }
36 @keyframes myrotate{
37     0%{
38         transform : rotate(0deg);
39     }
40     100%{
41         transform : rotate(360deg);
42     }
43 }
44 .rotateCD{
45     
46     -webkit-animation: myrotate 9.5s infinite linear;
47     -moz-animation: myrotate 9.5s infinite linear;
48     -ms-animation: myrotate 9.5s infinite linear;
49     -o-animation: myrotate 9.5s infinite linear;
50     animation: myrotate 9.5s infinite linear;
51     
52     -webkit-animation-play-state: running;
53     -moz-animation-play-state: running;
54     -ms-animation-play-state: running;
55     -o-animation-play-state: running;
56     animation-play-state: running;
57     
58     }
59 
60 /* module: bd */
61 #bd{width: 960px;margin: 200px auto 0;}
62 
63 /* module: musicBox */
64 #musicBox{position: relative;width: 430px;height: 430px;margin: 0 auto;overflow: hidden;}
65 #musicBox .cover{width: 300px;height: 300px;margin: 65px;background: url(../img/music1.jpg) 0 0 no-repeat;}
66 #musicBox .mask{position: absolute;top: 0;left: 0;width: 100%;height: 100%;background: url(../img/playerMask.png) 0 0 no-repeat;}
复制代码

  rotateCD这部分的代码兼容了多种高级浏览器(当然是支持css3的),设置了动画执行的时间和其他一些设置,你可以查询animate的更多知识来深入了解。

  对于上面的关于动画关键帧keyframes的写法,踩了比较多的坑,一开始,我是看《HTML5与CSS3权威指南》上的例子,它只写了chrome下的写法(比较坑爹,我猜测估计是作者认为其他浏览器的写法与此类似,所以让读者自己去摸索),我想当然的把其他浏览器的兼容性rotate设置写成了,如下面的代码所示:

复制代码
1 @-webkit-keyframes myrotate{
2     0%{
3         -webkit-transform : rotate(0deg);
4         -moz-transform : rotate(0deg);
5         -ms-transform : rotate(0deg);
6         -o-transform : rotate(0deg);
7         transform : rotate(0deg);
8     }
9         ....
复制代码

  这样导致的结果就是,chrome和safari下动画正常,FF、opera和IE下均无动画。其实这部分很好理解,myrotate的关键帧只是对webkit做了特殊说明,其他浏览器根本对此置之不理,所以没有动画的效果。

  因此,我们在写关键帧适配样式的时候,一定要写成下面的形式

复制代码
 1 @-webkit-keyframes myrotate{
 2     0%{
 3         -webkit-transform : rotate(0deg);
 4     }
 5         ...
 6 @-moz-keyframes myrotate{
 7     0%{
 8         -moz-transform : rotate(0deg);
 9         }
10         ...
11 @-ms-keyframes myrotate{
12     0%{
13         -ms-transform : rotate(0deg);
14         }
15         ...
16 @-o-keyframes myrotate{
17     0%{
18         -o-transform : rotate(0deg);
19         }
20         ...
21 @keyframes myrotate{
22     0%{
23         transform : rotate(0deg);
24         }
25         ...
复制代码

  opera浏览器还有个比较怪异的地方,它偏爱@keyframes myrotate{...},而对@-o-keyframes myrotate{...}不感冒,所以你发现两者只存其一的时候,前者可以实现动画,而后者不能实现动画效果。我一直对此很是不解,后来找到关于opera的介绍,说它是严格的执行W3C网页标准。这样想想,就明白了为什么它如此偏爱@keyframes myrotate{...}了。

  四、总结

  css3看起来非常美好,但是实际使用中还是存在不少的不确定性。如果不能看到已经实现的代码模板,你很难确信自己的代码格式就一定正确。所以你可以到http://daneden.me/animate/来观察各种动画效果,选择自己喜欢的动画并生成代码,下载下来后再按照自己的需求来编写动画代码。这样会让你的动画效果实现起来事半功倍(不要担心它达不到你的要求,上面有很多的效果,你可以自己组合,只要你的想象力够丰富)。

  好吧,本文到此结束。

  PS:文中使用到的浏览器为chrome(21.0.1180.15)、safari5.1.7(7534.57.2)、opera(12.11)、FF(17.0.1)和IE10(10.0.9200.16438)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值