os0x (owner)

Revisions

gist: 123561 Download_button fork
public
Public Clone URL: git://gist.github.com/123561.git
Embed All Files: show embed
tween2.js #
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// Tweener Like snippet
// var tw = new Tween(div.style,{time:1, onComplete:function(){},left:{to:0,from:100,tmpl:"$#px"}});
function Tween(item, opt) {
var self = this, TIME = 10, time = (opt.time||1) * 1000, TM_EXP = /(\+)?\$([\#\d])/g, sets = [],
easing = opt.transition || function(t, b, c, d){return c*t/d + b;}, _T = {time:1,onComplete:1,transition:1,delay:1};
for (var k in opt) if (!_T[k]) {
var set = opt[k], from = set.from || parseFloat(item[k]) || 0, values = [], tmpl = set.tmpl || '-$#';
sets.push({key:k, from:from, to:set.to, tmpl:tmpl});
}
var L = sets.length, delay = opt.delay*1000 || 0, startTime = new Date()*1 + delay, run = function(){
var now = new Date()*1, tim = self.prev = now - startTime;
for (var k = 0; k < L; ++k) {
var set = sets[k], val = easing(tim, set.from, set.to - set.from, time);
item[set.key] = set.tmpl.replace(TM_EXP, function(m, p, m1){return p && val < 0 ? 0 : (m1 == '#' ? val : val.toFixed(m1));});
}
if (tim <= time) {self.T=setTimeout(function(){run.call(self);},TIME);}
else {
for (var k = 0; k < L; ++k) {item[sets[k].key] = sets[k].tmpl.replace(TM_EXP, sets[k].to);}
if (typeof opt.onComplete == 'function') opt.onComplete(item);
self.end = true;
}
};
self.prev = 0;
this.restart = function(){
startTime = new Date()*1 - self.prev;
run();
};
this.pause = function(){
if(self.T){
clearTimeout(self.T);
self.T = null;
}
};
this.stop = function(){
if(self.T){
clearTimeout(self.T);
self.T = null;
self.prev = 0;
for (var k = 0; k < L; ++k) {
var set = sets[k], val = set.from;
item[set.key] = set.tmpl.replace(TM_EXP,
function(m, p, m1){return p && val < 0 ? 0 : (m1 == '#' ? val : val.toFixed(m1));});
}
}
};
delay ? this.T=setTimeout(function(){run();},delay) : run(0);
}