CSS3 animation实现逐帧动画效果


Posted in HTML / CSS onJune 02, 2016

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

animation属性一览

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

CSS3 animation实现逐帧动画效果

使用animation实现逐帧动画

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

CSS Code复制内容到剪贴板
  1. @keyframes run{   
  2.     from{   
  3.         background-position: 0 0;   
  4.     }   
  5.     to{   
  6.         background-position: -1540px 0 ;   
  7.     }   
  8. }   
  9. div{   
  10.     width:140px;   
  11.     height:140px;   
  12.     backgroundurl(run.png) ;   
  13.     animation-name:run;   
  14.     animation-duration:1s;   
  15.     animation-iteration-count:infinite;   
  16. }   
  17.   

CSS3 animation实现逐帧动画效果

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

CSS Code复制内容到剪贴板
  1. @keyframes run{   
  2.     0%, 8%{  /*动作一*/  }   
  3.     9.2%, 17.2%{  /*动作二*/  }   
  4.     ...   
  5. }   
  6.   

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

完整代码:

XML/HTML Code复制内容到剪贴板
  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(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>  

还有另外一个实现方法,就是利用steps(),就是帧之间的阶跃动画,这个在w3c里面没有写,先贴个图

CSS3 animation实现逐帧动画效果

由上图可知:

steps(1,start):动画一开始就跳到 100% 直到这一帧(不是整个周期)结束
steps(1,end):保持 0% 的样式直到这一帧(不是整个周期)结束

另外也可以直接设置 animation-timing-function:step-start/step-end
step-start效果等同于steps(1,start),step-end效果等同于steps(1,end)

最终效果,因为录制的问题可能有点卡顿,有兴趣的同学可以直接复制代码去跑下:

完整代码:

XML/HTML Code复制内容到剪贴板
  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%{   
  9.                 background-position: 0 0;   
  10.             }   
  11.             8.333%{   
  12.                 background-position: -140px 0;   
  13.             }   
  14.             16.666%{   
  15.                 background-position: -280px 0 ;   
  16.             }   
  17.             25.0%{   
  18.                 background-position: -420px 0 ;   
  19.             }   
  20.             33.333%{   
  21.                 background-position: -560px 0 ;   
  22.             }   
  23.             41.666%{   
  24.                 background-position: -700px 0 ;   
  25.             }   
  26.             50.0%{   
  27.                 background-position: -840px 0 ;   
  28.             }   
  29.             58.333%{   
  30.                 background-position: -980px 0 ;   
  31.             }   
  32.             66.666%{   
  33.                 background-position: -1120px 0 ;   
  34.             }   
  35.             75.0%{   
  36.                 background-position: -1260px 0 ;   
  37.             }   
  38.             83.333%{   
  39.                 background-position: -1400px 0 ;   
  40.             }   
  41.             91.666%{   
  42.                 background-position: -1540px 0 ;   
  43.             }   
  44.             100%{   
  45.                 background-position: 0 0 ;   
  46.             }   
  47.         }   
  48.         @-webkit-keyframes run{   
  49.             0%{   
  50.                 background-position: 0 0;   
  51.             }   
  52.             8.333%{   
  53.                 background-position: -140px 0;   
  54.             }   
  55.             16.666%{   
  56.                 background-position: -280px 0 ;   
  57.             }   
  58.             25.0%{   
  59.                 background-position: -420px 0 ;   
  60.             }   
  61.             33.333%{   
  62.                 background-position: -560px 0 ;   
  63.             }   
  64.             41.666%{   
  65.                 background-position: -700px 0 ;   
  66.             }   
  67.             50.0%{   
  68.                 background-position: -840px 0 ;   
  69.             }   
  70.             58.333%{   
  71.                 background-position: -980px 0 ;   
  72.             }   
  73.             66.666%{   
  74.                 background-position: -1120px 0 ;   
  75.             }   
  76.             75.0%{   
  77.                 background-position: -1260px 0 ;   
  78.             }   
  79.             83.333%{   
  80.                 background-position: -1400px 0 ;   
  81.             }   
  82.             91.666%{   
  83.                 background-position: -1540px 0 ;   
  84.             }   
  85.             100%{   
  86.                 background-position: 0 0 ;   
  87.             }   
  88.         }   
  89.         div{   
  90.             width:140px;   
  91.             height:140px;   
  92.             background: url(754767/201606/754767-20160601000042992-1734972084.png) ;   
  93.             animation:run 1s steps(1, start) infinite;   
  94.                 -webkit-animation:run 1s steps(1, start) infinite;   
  95.         }   
  96.         </style>  
  97.     </head>  
  98.     <body>  
  99.         <div></div>  
  100.     </body>  

CSS3 animation实现逐帧动画效果

原文地址:http://www.cnblogs.com/Fengzp/p/5548493.html

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS书写规范、顺序和命名规则
Mar 06 HTML / CSS
css3实现垂直下拉动画菜单示例
Apr 22 HTML / CSS
css3中背景尺寸background-size详解
Sep 02 HTML / CSS
html5-canvas中使用clip抠出一个区域的示例代码
May 25 HTML / CSS
分享一个页面平滑滚动小技巧(推荐)
Oct 23 HTML / CSS
html Table 表头固定的实现
Jan 22 HTML / CSS
HTML5 b和i标记将被赋予真正的语义
Jul 16 HTML / CSS
HTML5实现可缩放时钟代码
Aug 28 HTML / CSS
Html5 页面适配iPhoneX(就是那么简单)
Sep 05 HTML / CSS
原生CSS实现文字无限轮播的通用方法
Mar 30 HTML / CSS
HTML5+CSS+JavaScript实现捉虫小游戏设计和实现
Oct 16 HTML / CSS
CSS的calc函数用法小结
Jun 25 HTML / CSS
利用CSS3的线性渐变linear-gradient制作边框的示例
Jun 02 #HTML / CSS
移动端Web页面的CSS3 flex布局快速上手指南
May 31 #HTML / CSS
CSS3条纹背景制作的实战攻略
May 31 #HTML / CSS
CSS3实现多重边框的方法总结
May 31 #HTML / CSS
结合CSS3的新特性来总结垂直居中的实现方法
May 30 #HTML / CSS
图解CSS3制作圆环形进度条的实例教程
May 26 #HTML / CSS
CSS中的字体大小设置属性总结
May 24 #HTML / CSS
You might like
php短域名转换为实际域名函数
2011/01/17 PHP
php生成略缩图代码
2012/07/16 PHP
Joomla数据库操作之JFactory::getDBO用法
2016/05/05 PHP
php合并数组并保留键值的实现方法
2018/03/12 PHP
thinkphp5实现无限级分类
2019/02/18 PHP
getElementById在任意一款浏览器中都可以用吗的疑问回复
2007/05/13 Javascript
jQuery学习笔记(1)--用jQuery实现异步通信(用json传值)具体思路
2013/04/08 Javascript
点击按钮自动加关注的代码(sina微博/QQ空间/人人网/腾讯微博)
2014/01/02 Javascript
jQuery中index()的用法分析
2014/09/05 Javascript
JavaScript将一个数组插入到另一个数组的方法
2015/03/19 Javascript
jQuery实现的向下图文信息滚动效果
2015/05/03 Javascript
Ajax分页插件Pagination从前台jQuery到后端java总结
2016/07/22 Javascript
JavaScript的字符串方法汇总
2016/07/31 Javascript
js获取元素的标签名实现方法
2016/10/08 Javascript
详解js的延迟对象、跨域、模板引擎、弹出层、AJAX【附实例下载】
2016/12/19 Javascript
vue+axios实现登录拦截的实例代码
2017/05/22 Javascript
纯js实现无缝滚动功能代码实例
2020/02/21 Javascript
JavaScript中的this/call/apply/bind的使用及区别
2020/03/06 Javascript
vue调用微信JSDK 扫一扫,相册等需要注意的事项
2021/01/03 Vue.js
如何在现代JavaScript中编写异步任务
2021/01/31 Javascript
Python中list初始化方法示例
2016/09/18 Python
使用python遍历指定城市的一周气温
2017/03/31 Python
python 不同方式读取文件速度不同的实例
2018/11/09 Python
python实现一个简单的ping工具方法
2019/01/31 Python
Python函数装饰器原理与用法详解
2019/08/16 Python
米兰网婚纱礼服法国网上商店:Milanoo法国
2016/08/20 全球购物
美国女士时尚珠宝及配饰购物网站:Icing
2018/07/02 全球购物
俄语地区最大的中国商品在线购物网站之一:Umka Mall
2019/11/03 全球购物
外贸业务员求职信范文
2013/12/12 职场文书
2015年物业管理工作总结
2015/04/23 职场文书
谢师宴家长答谢词
2015/09/30 职场文书
写好求职信的技巧解密
2019/05/14 职场文书
python解决12306登录验证码的实现
2021/04/18 Python
Python源码解析之List
2021/05/21 Python
Win11 Build 21996.1 Dev版怎么样? win11系统截图欣赏
2021/11/21 数码科技
Nginx下SSL证书安装部署步骤介绍
2021/12/06 Servers