css3里面的animation属性非常强大,但是自己用的比较少,最近有次面试就刚好被问到了,趁现在有时间就对animation做一个小总结。同时实现一个逐帧动画的demo作为练习


animation属性一览

因为animation属性比较多,然后在w3c上看有点蛋疼,干脆也做了一份导图,以后想查看,就一目了然了

 css3 animation实现逐帧动画


使用animation实现逐帧动画

熟悉了animation的属性之后,得找个简单的小项目实现下,逐帧动画好有意思,先跑一个满足下自己
思路很简单,就是给元素一个雪碧图的背景,然后添加的帧动画更改background-position,关键代码:

@keyframes run{
    from{
        background-position: 0 0;
    }
    to{
        background-position: -1540px 0 ;
    }
}
div{
    width:140px;
    height:140px;
    background: url(run.png) ;
    animation-name:run;
    animation-duration:1s;
    animation-iteration-count:infinite;
}

css3 animation实现逐帧动画

但是跑起来后我们发现,每帧动画之间帧动画都是滑动,并不是我们要的效果,为什么呢?
原来animation默认以ease方式过渡,它会在每个关键帧之间插入补间动画,所以动画效果是连贯性的
知道原因就好办了,解决思路就是:

@keyframes run{
    0%, 8%{  /*动作一*/  }
    9.2%, 17.2%{  /*动作二*/  }
    ...
}

step1:动作之间停留8帧,0%设置动作一,动作一结束在8%
step2:动作之间过渡1.2帧,9.2%设置动作二,动作二结束在17.2%

完整代码:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>css3逐帧动画</title>
 6     <style>
 7     @keyframes run{
 8     0%, 8%{  background-position: 0 0;  }
 9     9.2%, 17.2%{  background-position: -140px 0;  }
10     18.4%, 26.4%{  background-position: -280px 0 ;  }
11     27.6%, 35.6%{  background-position: -420px 0 ;  }
12     36.8%, 44.8%{  background-position: -560px 0 ;  }
13     46%, 54%{  background-position: -700px 0 ;  }
14     55.2%, 63.2%{  background-position: -840px 0 ;  }
15     64.4%, 72.4%{  background-position: -980px 0 ;  }
16     73.6%, 81.6%{  background-position: -1120px 0 ;  }
17     82.8%, 90.8%{  background-position: -1400px 0 ;  }
18     92%, 100%{  background-position: -1540px 0 ;  }
19     }
20     @-webkit-keyframes run{
21     0%, 8%{  background-position: 0 0;  }
22     9.2%, 17.2%{  background-position: -140px 0;  }
23     18.4%, 26.4%{  background-position: -280px 0 ;  }
24     27.6%, 35.6%{  background-position: -420px 0 ;  }
25     36.8%, 44.8%{  background-position: -560px 0 ;  }
26     46%, 54%{  background-position: -700px 0 ;  }
27     55.2%, 63.2%{  background-position: -840px 0 ;  }
28     64.4%, 72.4%{  background-position: -980px 0 ;  }
29     73.6%, 81.6%{  background-position: -1120px 0 ;  }
30     82.8%, 90.8%{  background-position: -1400px 0 ;  }
31     92%, 100%{  background-position: -1540px 0 ;  }
32     }
33     div{
34         width:140px;
35         height:140px;
36         background: url(http://images2015.cnblogs.com/blog/754767/201606/754767-20160601000042992-1734972084.png) ;
37         animation:run 1s infinite;
38             -webkit-animation:run 1s infinite;
39         animation-fill-mode : backwards;
40             -webkit-animation-fill-mode : backwards;
41     }
42     </style>
43 </head>
44 <body>
45     <div></div>
46 </body>
47 </html>
View Code

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-09-17
  • 2022-01-17
  • 2021-07-22
  • 2021-12-09
猜你喜欢
  • 2022-12-23
  • 2021-12-04
  • 2021-06-14
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案