js缓动函数

tween: {
            easeInQuad: function(pos){
                return Math.pow(pos, 2);
            },
            easeOutQuad: function(pos){
                return -(Math.pow((pos-1), 2) -1);
            },
            easeInOutQuad: function(pos){
                if ((pos/=0.5) < 1) return 0.5*Math.pow(pos,2);
                return -0.5 * ((pos-=2)*pos - 2);
            },
            easeInCubic: function(pos){
                return Math.pow(pos, 3);
            },
            easeOutCubic: function(pos){
                return (Math.pow((pos-1), 3) +1);
            },
            easeInOutCubic: function(pos){
                if ((pos/=0.5) < 1) return 0.5*Math.pow(pos,3);
                return 0.5 * (Math.pow((pos-2),3) + 2);
            },
            easeInQuart: function(pos){
                return Math.pow(pos, 4);
            },
            easeOutQuart: function(pos){
                return -(Math.pow((pos-1), 4) -1)
            },
            easeInOutQuart: function(pos){
                if ((pos/=0.5) < 1) return 0.5*Math.pow(pos,4);
                return -0.5 * ((pos-=2)*Math.pow(pos,3) - 2);
            },
            easeInQuint: function(pos){
                return Math.pow(pos, 5);
            },
            easeOutQuint: function(pos){
                return (Math.pow((pos-1), 5) +1);
            },
            easeInOutQuint: function(pos){
                if ((pos/=0.5) < 1) return 0.5*Math.pow(pos,5);
                return 0.5 * (Math.pow((pos-2),5) + 2);
            },
            easeInSine: function(pos){
                return -Math.cos(pos * (Math.PI/2)) + 1;
            },
            easeOutSine: function(pos){
                return Math.sin(pos * (Math.PI/2));
            },
            easeInOutSine: function(pos){
                return (-.5 * (Math.cos(Math.PI*pos) -1));
            },
            easeInExpo: function(pos){
                return (pos==0) ? 0 : Math.pow(2, 10 * (pos - 1));
            },
            easeOutExpo: function(pos){
                return (pos==1) ? 1 : -Math.pow(2, -10 * pos) + 1;
            },
            easeInOutExpo: function(pos){
                if(pos==0) return 0;
                if(pos==1) return 1;
                if((pos/=0.5) < 1) return 0.5 * Math.pow(2,10 * (pos-1));
                return 0.5 * (-Math.pow(2, -10 * --pos) + 2);
            },
            easeInCirc: function(pos){
                return -(Math.sqrt(1 - (pos*pos)) - 1);
            },
            easeOutCirc: function(pos){
                return Math.sqrt(1 - Math.pow((pos-1), 2))
            },
            easeInOutCirc: function(pos){
                if((pos/=0.5) < 1) return -0.5 * (Math.sqrt(1 - pos*pos) - 1);
                return 0.5 * (Math.sqrt(1 - (pos-=2)*pos) + 1);
            },
            easeOutBounce: function(pos){
                if ((pos) < (1/2.75)) {
                    return (7.5625*pos*pos);
                } else if (pos < (2/2.75)) {
                    return (7.5625*(pos-=(1.5/2.75))*pos + .75);
                } else if (pos < (2.5/2.75)) {
                    return (7.5625*(pos-=(2.25/2.75))*pos + .9375);
                } else {
                    return (7.5625*(pos-=(2.625/2.75))*pos + .984375);
                }
            },
            easeInBack: function(pos){
                var s = 1.70158;
                return (pos)*pos*((s+1)*pos - s);
            },
            easeOutBack: function(pos){
                var s = 1.70158;
                return (pos=pos-1)*pos*((s+1)*pos + s) + 1;
            },
            easeInOutBack: function(pos){
                var s = 1.70158;
                if((pos/=0.5) < 1) return 0.5*(pos*pos*(((s*=(1.525))+1)*pos -s));
                return 0.5*((pos-=2)*pos*(((s*=(1.525))+1)*pos +s) +2);
            },
            elastic: function(pos) {
                return -1 * Math.pow(4,-8*pos) * Math.sin((pos*6-1)*(2*Math.PI)/2) + 1;
            },
            swingFromTo: function(pos) {
                var s = 1.70158;
                return ((pos/=0.5) < 1) ? 0.5*(pos*pos*(((s*=(1.525))+1)*pos - s)) :
                0.5*((pos-=2)*pos*(((s*=(1.525))+1)*pos + s) + 2);
            },
            swingFrom: function(pos) {
                var s = 1.70158;
                return pos*pos*((s+1)*pos - s);
            },
            swingTo: function(pos) {
                var s = 1.70158;
                return (pos-=1)*pos*((s+1)*pos + s) + 1;
            },
            bounce: function(pos) {
                if (pos < (1/2.75)) {
                    return (7.5625*pos*pos);
                } else if (pos < (2/2.75)) {
                    return (7.5625*(pos-=(1.5/2.75))*pos + .75);
                } else if (pos < (2.5/2.75)) {
                    return (7.5625*(pos-=(2.25/2.75))*pos + .9375);
                } else {
                    return (7.5625*(pos-=(2.625/2.75))*pos + .984375);
                }
            },
            bouncePast: function(pos) {
                if (pos < (1/2.75)) {
                    return (7.5625*pos*pos);
                } else if (pos < (2/2.75)) {
                    return 2 - (7.5625*(pos-=(1.5/2.75))*pos + .75);
                } else if (pos < (2.5/2.75)) {
                    return 2 - (7.5625*(pos-=(2.25/2.75))*pos + .9375);
                } else {
                    return 2 - (7.5625*(pos-=(2.625/2.75))*pos + .984375);
                }
            },
            easeFromTo: function(pos) {
                if ((pos/=0.5) < 1) return 0.5*Math.pow(pos,4);
                return -0.5 * ((pos-=2)*Math.pow(pos,3) - 2);
            },
            easeFrom: function(pos) {
                return Math.pow(pos,4);
            },
            easeTo: function(pos) {
                return Math.pow(pos,0.25);
            },
            linear:  function(pos) {
                return pos
            },
            sinusoidal: function(pos) {
                return (-Math.cos(pos*Math.PI)/2) + 0.5;
            },
            reverse: function(pos) {
                return 1 - pos;
            },
            mirror: function(pos, transition) {
                transition = transition || tween.sinusoidal;
                if(pos<0.5)
                    return transition(pos*2);
                else
                    return transition(1-(pos-0.5)*2);
            },
            flicker: function(pos) {
                var pos = pos + (Math.random()-0.5)/5;
                return tween.sinusoidal(pos < 0 ? 0 : pos > 1 ? 1 : pos);
            },
            wobble: function(pos) {
                return (-Math.cos(pos*Math.PI*(9*pos))/2) + 0.5;
            },
            pulse: function(pos, pulses) {
                return (-Math.cos((pos*((pulses||5)-.5)*2)*Math.PI)/2) + .5;
            },
            blink: function(pos, blinks) {
                return Math.round(pos*(blinks||5)) % 2;
            },
            spring: function(pos) {
                return 1 - (Math.cos(pos * 4.5 * Math.PI) * Math.exp(-pos * 6));
            },
            none: function(pos){
                return 0
            },
            full: function(pos){
                return 1
            }
        }
js缓动函数的更多相关文章
- JS —— 轮播图中的缓动函数的封装
		轮播图的根本其实就是缓动函数的封装,如果说轮播图是一辆跑动的汽车,那么缓动函数就是它的发动机,今天本文章就带大家由简入繁,封装属于自己的缓动函数~~ 我们从需求的角度开始,首先给出一个简单需求: 1. ... 
- GSAP JS基础教程--使用缓动函数
		今天来了解一下缓动easeing函数. 开始,如果你还没有GSAP的类包,可以到GreenSock的官网去下载最新版本的类包,或者直接点击这里来下载 学习之前,先来准备一下: <!DO ... 
- JS动画之缓动函数分析及动画库
		上一篇讲了JS动画定时器相关知识,这一篇介绍下缓动函数及流行的动画库. 熟悉的图 实际使用 jquery animate()+jquery.easing插件的使用: $(selector).anima ... 
- tween.js缓动(补间动画)
		一.理解tween.js 如果看到上面的已经理解了,可以跳过下面的部分.下面为对Tween.js的解释 下面就介绍如何使用这个Tween了,首先b.c.d三个参数(即初始值,变化量,持续时间)在缓动开 ... 
- NGUI缓动函数
		缓动函数:http://easings.net/zh-cn 研究NGUI的博客:http://dsqiu.iteye.com/category/295721 
- iOS基本动画/关键帧动画/利用缓动函数实现物理动画效果
		先说下基本动画部分 基本动画部分比较简单, 但能实现的动画效果也很局限 使用方法大致为: #1. 创建原始UI或者画面 #2. 创建CABasicAnimation实例, 并设置keypart/dur ... 
- Silverlight动画学习笔记(三):缓动函数
		(一)定义: 缓动函数:可以将自定义算术公式应用于动画 (二)为什么要用缓动函数: 您可能希望某一对象逼真地弹回或其行为像弹簧一样.您可以使用关键帧动画甚至 From/To/By 动画来大致模拟这些效 ... 
- EaseType 缓动函数
		EaseType(动画曲线) EaseType 缓动函数或者我习惯叫它动画曲线,在很多的软件或动画中都有涉及到,下面是摘取的一些资料: 缓函数图例 Tween效果 每一幅图像当鼠标移上去,会有路径效果 ... 
- 支持xcode6的缓动函数Easing以及使用示例
		支持xcode6的缓动函数Easing以及使用示例 用xcode6新建工程后,直接导致不支持之前的Easing缓动函数的代码,经过修改后就可以正常使用了,虽然比不上POP高大上的动画,但用缓动函数的动 ... 
随机推荐
- maven 本地仓库的配置
			<?xml version="1.0" encoding="UTF-8"?> <!--Licensed to the Apache Softw ... 
- HDU4910 Problem about GCD
			本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ... 
- python - pandas或者sklearn中如何将字符形式的标签数字化
			参考:http://www.php.cn/wenda/91257.html https://www.cnblogs.com/king-lps/p/7846414.html http://blog.cs ... 
- ASP.NET网站部署CentOS操作笔记
			ASP.NET 网站部署 Linux 服务器简要笔记 Mono 刚问世的时候,跑起来确实有很多不可预估的 BUG,但是被微软收购后推出的几个版本相对来说稳定了许多. 这几天使用了一个 n 年前用 We ... 
- 【hive】多表插入
			from or_table insert overwrite table1 name1 select … insert into table2 name2 select … 注意:select 后边不 ... 
- 个人学习jQuery笔记
			1.$(“#div1”).text()是获取id为div1的文本内容,也可以填充值 $(“#div1”).html() 是获取id 为div1的HTML内容值 也可以填充值 2.$(“#div1”)是 ... 
- 【fzu-2261】浪里个浪
			TonyY是一个喜欢到处浪的男人,他的梦想是带着兰兰姐姐浪遍天朝的各个角落,不过在此之前,他需要做好规划. 现在他的手上有一份天朝地图,上面有n个城市,m条交通路径,每条交通路径都是单行道.他已经预先 ... 
- CMDB Autoclient思路分析
			1.start.py里的script.run():执行run函数--> 2.script.py run方法--> 3.判断模式MODE(Agent/SSHSALT)-->4.执行cl ... 
- LeetCode OJ:Swap Nodes in Pairs(成对交换节点)
			Given a linked list, swap every two adjacent nodes and return its head. For example,Given 1->2-&g ... 
- js 验证对象是否为数组
			一.方法一:用到了原型 由于typeof检测数组,只会显示其为object,并不会详细到告诉我们是否为array,所以我们可以自己写个js用原型来检测: <script> /** * * ... 
