diff options
author | Ulrich-Matthias Schäfer <ulima.ums@googlemail.com> | 2015-12-13 21:41:13 +0100 |
---|---|---|
committer | Ulrich-Matthias Schäfer <ulima.ums@googlemail.com> | 2015-12-13 21:41:13 +0100 |
commit | 3260b94a26d033112ea9d027faa23152cf24c1ea (patch) | |
tree | e1cb7b3c88e1167c46dbccd6f3c3f60e2aebdf07 /src/fxnew.js | |
parent | f3e185674c85ca9f71c72cafa4f89491f5559983 (diff) | |
download | svg.js-3260b94a26d033112ea9d027faa23152cf24c1ea.tar.gz svg.js-3260b94a26d033112ea9d027faa23152cf24c1ea.zip |
added once and during
Diffstat (limited to 'src/fxnew.js')
-rw-r--r-- | src/fxnew.js | 67 |
1 files changed, 53 insertions, 14 deletions
diff --git a/src/fxnew.js b/src/fxnew.js index c419057..cdfebe1 100644 --- a/src/fxnew.js +++ b/src/fxnew.js @@ -20,6 +20,7 @@ SVG.Situation = SVG.invent({ this.easing = SVG.easing[o.easing || '-'] || o.easing // when easing is a function, its not in SVG.easing this.pos = 0 // position before easing + this.lastPos = 0 // needed for once callbacks this.paused = false this.finished = false this.active = false @@ -30,6 +31,11 @@ SVG.Situation = SVG.invent({ // e.g. x: [SVG.Number, 5] // this way its assured, that the start value is set correctly } + + this._once = { + // functions to fire at a specific position + // e.g. "0.5": function foo(){} + } } @@ -54,9 +60,7 @@ SVG.Situation = SVG.invent({ } , start: function(){ - - - + if(this.fx().current() == this){ // morph values from the current position to the destination - maybe move this to another place for(var i in this.animations){ @@ -153,6 +157,14 @@ SVG.Situation = SVG.invent({ if(this.pos > 1) this.pos = 1 if(this.pos < 0) this.pos = 0 + var eased = this.easing(this.pos) + + for(var i in this._once){ + if(i > this.lastPos && i < eased) this._once[i](this.pos, eased) + } + + this.fx().target.fire('during', {pos: this.pos, eased: eased}) + this.eachAt(function(method, args){ this.fx().target[method].apply(this.fx().target, args) }) @@ -160,13 +172,16 @@ SVG.Situation = SVG.invent({ if(this.pos == 1){ this.finished = true this.active = false - var next = this.fx().next() - if(next)next.start() + this.fx().target.fire('situationfinished') + this.fx().startNext() + //var next = this.fx().next() + //if(next)next.start() cancelAnimationFrame(this.animationFrame) }else{ this.startAnimFrame() } + this.lastPos = eased return this } @@ -194,6 +209,17 @@ SVG.Situation = SVG.invent({ return this._fx } + + + , once: function(pos, fn, isEased){ + + if(!isEased)pos = this.easing(pos) + + this._once[pos] = fn + + return this + } + } }) @@ -243,16 +269,16 @@ SVG.FX = SVG.invent({ if(!attr) continue // if not yet morphed we extract the destination from the array - if(attr instanceof Array) return attr[1] + //if(attr instanceof Array) return attr[1] // otherwise from the morphed object return attr.destination - + } - + // return the elements attribute as fallback return this.target[attr]() - + } , prev: function() { @@ -267,27 +293,40 @@ SVG.FX = SVG.invent({ if(!this._queue[i]) return null return this._queue[i] } + + , startNext: function() { + + var next = this.next() + if(next) next.start() + else this.finish() + + return this + } , pause: function() { - this.active = false + this.current().pause() + return this } , play: function() { - this.reverse = false - this.active = true + this.current().play() + return this } + /* , resume: function() { this.active = true - } + }*/ , finish: function() { this.active = false - return this.progress(1) + this.target.fire('fxfinished') + return this } , reverse: function() { this.reverse = true + this.current().play() return this } |