CSS3 animation实现逐帧动画效果示例介绍

这篇文章主要介绍了css3 animation实现逐帧动画效果示例介绍,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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 ;       }   }   p{       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%

完整代码:

nbsp;html>                css3逐帧动画            @keyframes run{       0%, 8%{  background-position: 0 0;  }       9.2%, 17.2%{  background-position: -140px 0;  }       18.4%, 26.4%{  background-position: -280px 0 ;  }       27.6%, 35.6%{  background-position: -420px 0 ;  }       36.8%, 44.8%{  background-position: -560px 0 ;  }       46%, 54%{  background-position: -700px 0 ;  }       55.2%, 63.2%{  background-position: -840px 0 ;  }       64.4%, 72.4%{  background-position: -980px 0 ;  }       73.6%, 81.6%{  background-position: -1120px 0 ;  }       82.8%, 90.8%{  background-position: -1400px 0 ;  }       92%, 100%{  background-position: -1540px 0 ;  }       }       @-webkit-keyframes run{       0%, 8%{  background-position: 0 0;  }       9.2%, 17.2%{  background-position: -140px 0;  }       18.4%, 26.4%{  background-position: -280px 0 ;  }       27.6%, 35.6%{  background-position: -420px 0 ;  }       36.8%, 44.8%{  background-position: -560px 0 ;  }       46%, 54%{  background-position: -700px 0 ;  }       55.2%, 63.2%{  background-position: -840px 0 ;  }       64.4%, 72.4%{  background-position: -980px 0 ;  }       73.6%, 81.6%{  background-position: -1120px 0 ;  }       82.8%, 90.8%{  background-position: -1400px 0 ;  }       92%, 100%{  background-position: -1540px 0 ;  }       }       p{           width:140px;           height:140px;           background: url(blog/754767/201606/754767-20160601000042992-1734972084.png) ;           animation:run 1s infinite;               -webkit-animation:run 1s infinite;           animation-fill-mode : backwards;               -webkit-animation-fill-mode : backwards;       }                 

    

登录后复制

还有另外一个实现方法,就是利用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)

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

完整代码:

nbsp;html>                                css3逐帧动画                    @keyframes run{               0%{                   background-position: 0 0;               }               8.333%{                   background-position: -140px 0;               }               16.666%{                   background-position: -280px 0 ;               }               25.0%{                   background-position: -420px 0 ;               }               33.333%{                   background-position: -560px 0 ;               }               41.666%{                   background-position: -700px 0 ;               }               50.0%{                   background-position: -840px 0 ;               }               58.333%{                   background-position: -980px 0 ;               }               66.666%{                   background-position: -1120px 0 ;               }               75.0%{                   background-position: -1260px 0 ;               }               83.333%{                   background-position: -1400px 0 ;               }               91.666%{                   background-position: -1540px 0 ;               }               100%{                   background-position: 0 0 ;               }           }           @-webkit-keyframes run{               0%{                   background-position: 0 0;               }               8.333%{                   background-position: -140px 0;               }               16.666%{                   background-position: -280px 0 ;               }               25.0%{                   background-position: -420px 0 ;               }               33.333%{                   background-position: -560px 0 ;               }               41.666%{                   background-position: -700px 0 ;               }               50.0%{                   background-position: -840px 0 ;               }               58.333%{                   background-position: -980px 0 ;               }               66.666%{                   background-position: -1120px 0 ;               }               75.0%{                   background-position: -1260px 0 ;               }               83.333%{                   background-position: -1400px 0 ;               }               91.666%{                   background-position: -1540px 0 ;               }               100%{                   background-position: 0 0 ;               }           }           p{               width:140px;               height:140px;               background: url(754767/201606/754767-20160601000042992-1734972084.png) ;               animation:run 1s steps(1, start) infinite;                   -webkit-animation:run 1s steps(1, start) infinite;           }                                 

      

登录后复制

CSS3 animation实现逐帧动画效果示例介绍

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持PHP中文网。

以上就是CSS3 animation实现逐帧动画效果示例介绍的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2905980.html

(0)
上一篇 2025年3月11日 02:33:32
下一篇 2025年3月11日 02:33:37

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 分享CSS两列布局实现方式的总结

    这篇文章主要介绍了css两列布局实现方式的总结,讨论了包括absolute + margin和float + margin方式的一些实践和问题,需要的朋友可以参考下 两列布局大概是最经典的一种网页布局方式了,本博客就是采用的这种布局。两列布…

    编程技术 2025年3月11日
    200
  • css全屏背景图片设置django加载图片路径详细说明

    下面小编就为大家带来一篇css全屏背景图片设置,django加载图片路径详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 css全屏背景图片设置,django加载图片路径详解 #bg { position:…

    编程技术 2025年3月11日
    200
  • 使用CSS清除浮动的方法详解

    这篇文章主要介绍了使用css清除浮动的方法详解,值得注意的是并不是每次单纯把浮动清除掉就可以解决相关问题,文中最后谈到的闭合浮动的方案也非常值得一试,需要的朋友可以参考下 清除浮动方法方法一:使用带clear属性的空元素 在浮动元素后使用一…

    2025年3月11日
    200
  • 必看的css权威指南笔记

    下面小编就为大家带来一篇必看的css权威指南笔记。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 第1章 css和文档 1,元素:替换元素(img input),非替换元素(大多数span)。 2,link:r…

    编程技术 2025年3月11日
    200
  • 使用CSS实现标题文字过长部分显示省略号的方法介绍

    这篇文章主要介绍了使用CSS实现标题文字过长部分显示省略号的方法介绍,并且讲解了针对单行文字溢出和多行文字溢出的情况,需要的朋友可以参考下前段时间在公司移动站的重构,遇到了一个产品列表title的需求是只显示两行,然后超过两行的字符用省略号…

    编程技术 2025年3月11日
    200
  • CSS代码书写规范的学习指南

    这里为大家送上一份css代码书写规范的学习指南,包括代码注释和命名规范以及空格缩进等一应俱全,都来自大家平时的约定俗成,绝对值得学习借鉴,需要的朋友可以参考下 1.格式化代码1.1文件[建议]:CSS文件使用无BOM的UTF-8编码1.2缩…

    编程技术 2025年3月11日
    200
  • 分享CSS字符编码引起乱码快速解决的方法

    下面小编就为大家带来一篇分享css字符编码引起乱码快速解决的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 乱码引起的CSS失效原理: 由于一个中文是两个字符组成,在编码不一致的情况下会引发字符的“重新”…

    编程技术 2025年3月11日
    200
  • 使用CSS的margin属性在页面布局中的使用攻略介绍

    margin属性可以决定很多html元素的宽高度,因而在布局方面也能够有很重要的作用,接下来我们就来看一下使用css的margin属性在页面布局中的使用攻略介绍 基础 1.元素containing-box宽高度等于内容宽度 HTML    …

    2025年3月11日 编程技术
    200
  • css实现3D立方体旋转特效的示例代码

    这篇文章介绍css实现3d立方体旋转特效的示例代码 先来看运行后出来的效果 它是在不停运行的一个立方体 立即学习“前端免费学习笔记(深入)”; 先来看html部分的代码                                    …

    2025年3月11日
    200
  • 关于CSS知识点的集锦

    这篇文章介绍关于css知识点的集锦 CreateTime–2016年9月29日09:43:10Author:Marydon1.背景色线性渐变 background-color:linear-gradient(100deg,#FF…

    编程技术 2025年3月11日
    200

发表回复

登录后才能评论