animation-timing-function的steps详解

W3C里的定义:

animation-timing-function 规定动画的速度曲线。

这个属性有很多取值,

linear:
线性过渡。等同于贝塞尔曲线(0.0, 0.0, 1.0, 1.0)
ease:
平滑过渡。等同于贝塞尔曲线(0.25, 0.1, 0.25, 1.0)
ease-in:
由慢到快。等同于贝塞尔曲线(0.42, 0, 1.0, 1.0)
ease-out:
由快到慢。等同于贝塞尔曲线(0, 0, 0.58, 1.0)
ease-in-out:
由慢到快再到慢。等同于贝塞尔曲线(0.42, 0, 0.58, 1.0)
step-start:
等同于 steps(1, start)
step-end:
等同于 steps(1, end)
steps(<integer>[, [ start | end ] ]?):
接受两个参数的步进函数。第一个参数必须为正整数,指定函数的步数。第二个参数取值可以是start或end,指定每一步的值发生变化的时间点。第二个参数是可选的,默认值为end。
cubic-bezier(<number>, <number>, <number>, <number>):
特定的贝塞尔曲线类型,4个数值需在[0, 1]区间内

然后今天我想巴拉的是steps(1,start)和steps(1,end)的区别;

首先,

steps(<integer>[, [ start | end ] ]?):

接受两个参数的步进函数。

第一个参数必须为正整数,指定了函数中的间隔数量。

第二个参数取值可以是start或end,指定每一步的值发生变化的时间点。

第二个参数是可选的,默认值为end。

step-start等同于steps(1,start),动画分成1步,动画执行时为开始左侧端点的部分为开始;

step-end等同于steps(1,end):动画分成一步,动画执行时以结尾端点为开始,默认值为end。

上例子吧!


  .bird{
    min-width: 91px;
    min-height: 71px;
    background: url(../img/bird.png) -182px 0px no-repeat;
  }

.birdFly {
    animation: bird-slow 900ms infinite steps(1,start);
}
@keyframes bird-slow{
    0% {
        background-position: -182px 0px;//第三只小鸟
    }
    50% {
        background-position: 0px 0px;//第一只小鸟
    }
    75% {
        background-position: -91px 0px;//第二只小鸟
    }
    100% {
        background-position: -182px 0px;//第三只小鸟
    }
}

图片是这张雪碧图;动画效果就是模拟小鸟展翅飞翔,一直扇动翅膀;默认是先显示第三只小鸟

steps(1,start);第一个参数为1的意思就是,每俩关键帧之间只要1步完成,也就是0%-50%,只分为一步完成,50%-75%,也是一步完成;以此类推;注意steps的设置都是针对两个关键帧之间的,而非是整个keyframes;

timing-function 作用于每两个关键帧之间,而不是整个动画。

steps(1,start) : 第一只鸟和第二只鸟相互切换
steps(1,end) : 第三只鸟和第一只鸟相互切换

start跳过0%,end跳过100%

step-start在变化过程中,都是以下一帧的显示效果来填充间隔动画,所以0% 到 50%  直接就显示了第一只鸟

step-end与上面相反,都是以上一帧的显示效果来填充间隔动画,所以0% 到 50% 直接就显示了第三只鸟

然后思考下,此时我们设置成start,小鸟会是怎样的呢?

答案是:

start:进入页面就会显示第一只小鸟,因为跳过了0%;

end:进入页面就会显示第三只小鸟,因为跳过了100%;

所以如果你一进来想显示小鸟展翅的样子就得是start,如果是一进来展示小鸟收翅膀的样子,那就设置成end;

个人觉得一进来看到小鸟展翅的样子还是比较喜欢的,哇哈哈哈、

再说下"forwards"和"infinite"

使用"forwards"和"infinite"对步数的的作用是不同的。

如果我们改变成"infinite",将不会出现"100%",因为"forwards"命令使动画在我们设置的步数外添加了额外的一步。

"forwards"使动画保持结束时的状态,所以在步数执行完毕后,动画会跳到最后一帧的状态并保持不变。

(做那种雨滴滴下来,然后种子就发芽,然后就长成了参天大树,就定格到最后一帧的大树的效果;animation: grow 5000ms forwards steps(20);这里的steps是你的雪碧图里的图片的数量减一哦)

总结:

steps函数,它可以传入两个参数,第一个是分成多少步完成,第二个参数可选,决定显示效果(是上一帧填充还是下一帧填充);

steps的设置都是针对两个关键帧之间的,而非是整个keyframes;

timing-function 作用于每两个关键帧之间,而不是整个动画;

"forwards"命令使动画在我们设置的步数外添加了额外的一步。

原文地址:https://www.cnblogs.com/qiufang/p/8893013.html

时间: 2024-10-20 20:53:18

animation-timing-function的steps详解的相关文章

animation-timing-function: steps() 详解

在应用 CSS3 渐变/动画时,有个控制时间的属性 <animation-timing-function> .它的取值中除了常用到的 贝萨尔曲线以外,还有个让人比较困惑的 steps() 函数. teps(n,start/end) 第一个参数 number 为指定的间隔数,即把动画分为 n 步阶段性展示,第二个参数默认为 end,设置最后一步的状态,start 为结束时的状态,end 为开始时的状态. steps 有两个参数 第一个肯定是分几步执行完 第二个有两个值 start 第一帧是第一步

(function($){...})(jQuery) 函数详解

function(arg){...} 这是一个匿名函数,参数是arg. 而调用匿名函数时,是在函数后面写上括号和实参的,由于操作符的优先级,函数本身也需要用括号,即: function(arg){...}(param) , 这相当于定义了一个参数为arg的匿名函数,并且将param作为实参来调用这个匿名函数. 而(function($){...})(jQuery)则是一样的,之所以只在形参使用$,是为了不与其他库冲突,所以实参用jQuery. (funtion(){})():立即执行函数:相当于

JavaScript Function.apply() 函数详解

语法 functionObject.apply( [ thisObj [, argsArray ]] ) apply()函数用于调用当前函数functionObject,并可同时使用指定对象thisObj作为本次函数执行时函数内部的this指针引用. 该函数属于Function对象,所有主流浏览器均支持该函数. 参数 参数 描述 thisObj 可选/Object类型指定执行functionObject函数时,函数内部this指针引用的对象. argsArray 可选/Array|argumen

ExtJS:GridPanel之renderer:function()和itemdblclick : function()方法参数详解

要使用GridPanel,首先要定义Store,而在创建Store的时候必须要有Model,因此我们首先来定义Model: Ext.define("Gpsdata", { extend: "Ext.data.Model", fields: [ { name: 'gpstime', type: 'string' }, { name: 'gpstemp', type: 'string' } ] }); 然后创建Store: var surfacestore = new

javascript AJAX与Comet详解

          博客专家福利      [限时活动]建专辑得大奖       专访荣浩:流程的永恒之道      当青春遇上互联网,能否点燃你的创业梦      推荐有礼--找出您心中的技术大牛 javascript AJAX与Comet详解 分类: javascript2012-12-24 17:39 367人阅读 评论(0) 收藏 举报 XMLHttpRequest对象 在IE5中,XHR对象是通过MSXML库中的ActiveX对象实现的.在IE中可能会遇到三种不同版本的XHR对象,即M

属性动画详解一(Property Animation)

效果图: Android动画有两类: 1.View Animation(Frame Animation,Tween Animation) 2.Property Animation 其中,上述效果是用第二类属性动画做的. 什么是属性动画? 通俗的说,属性动画就是在一定的时间内,按照一定的规律来改变对象的属性(该属性对于该对象应该是从形态(大小,位置等)上可以感受到的),从而是对象展现出动画的效果. 作用:可以定义动画来改变对象的属性( You can define an animation to

css动画-animation各个属性详解(转)

CSS3的animation很容易就能实现各种酷炫的动画,虽然看到别人的成果图会觉得很难,但是如果掌握好各种动画属性,做好酷炫吊炸天的动画都不在话下,好,切入正题. 一.动画属性: 动画属性包括:①animation-name,②animation-duration,③animation-timing-function, 以下是各属性详解: 1.animation-name:指定要绑定到选择器的关键帧的名称. 2.animation-duration:定义动画完成一个周期需要多少秒或毫秒 3.a

超级强大的SVG SMIL animation动画详解

本文花费精力惊人,具有先驱前瞻性,转载规则以及申明见文末,当心予以追究.本文地址:http://www.zhangxinxu.com/wordpress/?p=4333 //zxx: 本文的SVG在有缓存时候是无动画效果,此时您可以试着[右键-新标签页打开图片]. 一.SVG SMIL animation概览 1. SMIL是什么?SMIL不是指「水蜜梨」,而是Synchronized Multimedia Integration Language(同步多媒体集成语言)的首字母缩写简称,是有标准

Animation动画详解(五)——ValueAnimator高级进阶(一)

前言:唯有脚踏实地,才能厚积薄发,未来只属于为梦想而奋斗的人们,今天的你决定未来的自己. 上一篇给大家介绍了ValueAnimator的大部分函数的用法,不过还都是些简单的用法,这篇我们带大家来看看有关加速器.animator和keyFrame的知识. 一.插值器 插值器,也叫加速器:有关插值器的知识,我在<Animation动画详解(二)--Interpolator插值器>中专门讲过,大家可以先看看这篇文章中各个加速器的效果.这里再讲一下什么是插值器.我们知道,我们通过ofInt(0,400