js-運動框架(時間版)

週末的時候,在網上看了一篇教程,內容是說jquery的animate運動函數是如何實現的,看完以後本身就抽出了一些時間將以前的運動框架改了一下,改完以後發現效果很是好,而卻運動形式也豐富了不少!jquery

代碼以下:json

 
 
  1 //obj:運動對象,json:運動屬性json格式,times:運動時間(不能大於間隔時間),fx:運動形式,fn:回掉函數
  2 
  3 function  startMove(obj,json,times,fx,fn){
  4       var startTime=now();
  5       var iCur={};
  6       for(var attr in json){
  7           
  8            iCur[attr]=0;
  9            if(attr=="opacity"){
 10                
 11                 iCur[attr]=Math.round(getStyle(obj,attr)*100);   
 12            }else{
 13                
 14                  iCur[attr]=parseInt(getStyle(obj,attr));   
 15            }
 16   
 17       }
 18       clearInterval(obj.timer);
 19       obj.timer=setInterval(function(){
 20       var changeTime=now();
 21        
 22       var scale = 1 -  Math.max(0,startTime  -  changeTime + times)/times ; 
 23 
 24 
 25 
 26       for(var attr in json ){
 27 
 28             var cvalue=parseInt(json[attr])-iCur[attr];
 29             console.log(cvalue);
 30 
 31           var value=Tween[fx](scale*times,iCur[attr],cvalue,times);
 32 
 33               
 34           if(attr=="opacity"){
 35               
 36               obj.style.filter="alpha(opacity="+value+")";
 37               obj.style.opacity=value/100;
 38               
 39           }else{
 40               
 41               obj.style[attr]=value+"px";
 42   
 43          }
 44   
 45      }
 46      if(scale == 1){
 47         clearInterval(obj.timer);
 48         if(fn){
 49             fn.call(obj);
 50         }
 51     }
 52   
 53           
 54       },13);
 55       
 56 //取得當前時間      
 57      function now(){
 58          return (new Date()).getTime();     
 59      } 
 60      
 61 //得到樣式值     
 62      function getStyle(obj,sty){
 63           if(obj.currentStyle){
 64              
 65              return obj.currentStyle[sty];  
 66               
 67           }else{
 68               
 69              return window.getComputedStyle(obj,false)[sty];  
 70               
 71           }
 72 
 73     }
 74     
 75 //運動公式     
 76 var Tween = {
 77     
 78     //t : 當前時間   b : 初始值  c : 變化值   d : 總時間
 79     //return : 當前的位置 
 80     
 81     linear: function (t, b, c, d){  //勻速
 82         return c*t/d + b;
 83     },
 84     easeIn: function(t, b, c, d){  //加速曲線
 85         return c*(t/=d)*t + b;
 86     },
 87     easeOut: function(t, b, c, d){  //減速曲線
 88         return -c *(t/=d)*(t-2) + b;
 89     },
 90     easeBoth: function(t, b, c, d){  //加速減速曲線
 91         if ((t/=d/2) < 1) {
 92             return c/2*t*t + b;
 93         }
 94         return -c/2 * ((--t)*(t-2) - 1) + b;
 95     },
 96     easeInStrong: function(t, b, c, d){  //加加速曲線
 97         return c*(t/=d)*t*t*t + b;
 98     },
 99     easeOutStrong: function(t, b, c, d){  //減減速曲線
100         return -c * ((t=t/d-1)*t*t*t - 1) + b;
101     },
102     easeBothStrong: function(t, b, c, d){  //加加速減減速曲線
103         if ((t/=d/2) < 1) {
104             return c/2*t*t*t*t + b;
105         }
106         return -c/2 * ((t-=2)*t*t*t - 2) + b;
107     },
108     elasticIn: function(t, b, c, d, a, p){  //正弦衰減曲線(彈動漸入)
109         if (t === 0) { 
110             return b; 
111         }
112         if ( (t /= d) == 1 ) {
113             return b+c; 
114         }
115         if (!p) {
116             p=d*0.3; 
117         }
118         if (!a || a < Math.abs(c)) {
119             a = c; 
120             var s = p/4;
121         } else {
122             var s = p/(2*Math.PI) * Math.asin (c/a);
123         }
124         return -(a*Math.pow(2,10*(t-=1)) * Math.sin( (t*d-s)*(2*Math.PI)/p )) + b;
125     },
126     elasticOut: function(t, b, c, d, a, p){    //正弦加強曲線(彈動漸出)
127         if (t === 0) {
128             return b;
129         }
130         if ( (t /= d) == 1 ) {
131             return b+c;
132         }
133         if (!p) {
134             p=d*0.3;
135         }
136         if (!a || a < Math.abs(c)) {
137             a = c;
138             var s = p / 4;
139         } else {
140             var s = p/(2*Math.PI) * Math.asin (c/a);
141         }
142         return a*Math.pow(2,-10*t) * Math.sin( (t*d-s)*(2*Math.PI)/p ) + c + b;
143     },    
144     elasticBoth: function(t, b, c, d, a, p){
145         if (t === 0) {
146             return b;
147         }
148         if ( (t /= d/2) == 2 ) {
149             return b+c;
150         }
151         if (!p) {
152             p = d*(0.3*1.5);
153         }
154         if ( !a || a < Math.abs(c) ) {
155             a = c; 
156             var s = p/4;
157         }
158         else {
159             var s = p/(2*Math.PI) * Math.asin (c/a);
160         }
161         if (t < 1) {
162             return - 0.5*(a*Math.pow(2,10*(t-=1)) * 
163                     Math.sin( (t*d-s)*(2*Math.PI)/p )) + b;
164         }
165         return a*Math.pow(2,-10*(t-=1)) * 
166                 Math.sin( (t*d-s)*(2*Math.PI)/p )*0.5 + c + b;
167     },
168     backIn: function(t, b, c, d, s){     //回退加速(回退漸入)
169         if (typeof s == 'undefined') {
170            s = 1.70158;
171         }
172         return c*(t/=d)*t*((s+1)*t - s) + b;
173     },
174     backOut: function(t, b, c, d, s){
175         if (typeof s == 'undefined') {
176             s = 3.70158;  //回縮的距離
177         }
178         return c*((t=t/d-1)*t*((s+1)*t + s) + 1) + b;
179     }, 
180     backBoth: function(t, b, c, d, s){
181         if (typeof s == 'undefined') {
182             s = 1.70158; 
183         }
184         if ((t /= d/2 ) < 1) {
185             return c/2*(t*t*(((s*=(1.525))+1)*t - s)) + b;
186         }
187         return c/2*((t-=2)*t*(((s*=(1.525))+1)*t + s) + 2) + b;
188     },
189     bounceIn: function(t, b, c, d){    //彈球減振(彈球漸出)
190         return c - Tween['bounceOut'](d-t, 0, c, d) + b;
191     },       
192     bounceOut: function(t, b, c, d){
193         if ((t/=d) < (1/2.75)) {
194             return c*(7.5625*t*t) + b;
195         } else if (t < (2/2.75)) {
196             return c*(7.5625*(t-=(1.5/2.75))*t + 0.75) + b;
197         } else if (t < (2.5/2.75)) {
198             return c*(7.5625*(t-=(2.25/2.75))*t + 0.9375) + b;
199         }
200         return c*(7.5625*(t-=(2.625/2.75))*t + 0.984375) + b;
201     },      
202     bounceBoth: function(t, b, c, d){
203         if (t < d/2) {
204             return Tween['bounceIn'](t*2, 0, c, d) * 0.5 + b;
205         }
206         return Tween['bounceOut'](t*2-d, 0, c, d) * 0.5 + c*0.5 + b;
207     }
208 } 
209 
210 }
相關文章
相關標籤/搜索