diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/animation/Morphable.js | 7 | ||||
-rw-r--r-- | src/animation/Runner.js | 43 | ||||
-rw-r--r-- | src/animation/Timeline.js | 5 | ||||
-rw-r--r-- | src/modules/core/attr.js | 2 | ||||
-rw-r--r-- | src/types/Box.js | 5 | ||||
-rw-r--r-- | src/types/Color.js | 3 | ||||
-rw-r--r-- | src/types/EventTarget.js | 3 | ||||
-rw-r--r-- | src/types/List.js | 6 | ||||
-rw-r--r-- | src/types/Matrix.js | 3 |
9 files changed, 60 insertions, 17 deletions
diff --git a/src/animation/Morphable.js b/src/animation/Morphable.js index 56ffe95..0f191c9 100644 --- a/src/animation/Morphable.js +++ b/src/animation/Morphable.js @@ -90,7 +90,12 @@ export default class Morphable { this._morphObj = this._morphObj || new this._type() this._context = this._context - || Array.apply(null, Array(result.length)).map(Object) + || Array.apply(null, Array(result.length)) + .map(Object) + .map(function (o) { + o.done = true + return o + }) return result } diff --git a/src/animation/Runner.js b/src/animation/Runner.js index 3af5823..d211876 100644 --- a/src/animation/Runner.js +++ b/src/animation/Runner.js @@ -1,5 +1,5 @@ import { Controller, Ease, Stepper } from './Controller.js' -import { extend } from '../utils/adopter.js' +import { extend, register } from '../utils/adopter.js' import { from, to } from '../modules/core/gradiented.js' import { getOrigin } from '../utils/utils.js' import { noop, timeline } from '../modules/core/defaults.js' @@ -64,6 +64,9 @@ export default class Runner extends EventTarget { this._swing = false this._wait = 0 this._times = 1 + + // Stores how long a runner is stored after beeing done + this._persist = this._isDeclarative ? true : null } /* @@ -199,6 +202,12 @@ export default class Runner extends EventTarget { return this.time(time) } + persist (dtOrForever) { + if (dtOrForever == null) return this._persist + this._persist = dtOrForever + return this + } + position (p) { // Get all of the variables we need var x = this._time @@ -338,11 +347,22 @@ export default class Runner extends EventTarget { morpher: morpher, caller: this._queue[this._queue.length - 1] } + + // We have to resume the timeline in case a controller + // is already done without beeing ever run + // This can happen when e.g. this is done: + // anim = el.animate(new SVG.Spring) + // and later + // anim.move(...) + if (this._isDeclarative) { + var timeline = this.timeline() + timeline && timeline.play() + } } // Try to set the target for a morpher if the morpher exists, otherwise // do nothing and return false - _tryRetarget (method, target) { + _tryRetarget (method, target, extra) { if (this._history[method]) { // if the last method wasnt even initialised, throw it away if (!this._history[method].caller.initialised) { @@ -354,7 +374,7 @@ export default class Runner extends EventTarget { // for the case of transformations, we use the special retarget function // which has access to the outer scope if (this._history[method].caller.retarget) { - this._history[method].caller.retarget(target) + this._history[method].caller.retarget(target, extra) // for everything else a simple morpher change is sufficient } else { this._history[method].morpher.to(target) @@ -362,7 +382,7 @@ export default class Runner extends EventTarget { this._history[method].caller.finished = false var timeline = this.timeline() - timeline && timeline._continue() + timeline && timeline.play() return true } return false @@ -604,7 +624,7 @@ registerMethods({ .reduce(lmultiply, new Matrix()) }, - addRunner (runner) { + _addRunner (runner) { this._transformationRunners.add(runner) Animator.transform_frame( @@ -636,9 +656,10 @@ extend(Runner, { styleAttr (type, name, val) { // apply attributes individually if (typeof name === 'object') { - for (var key in val) { - this.styleAttr(type, key, val[key]) + for (var key in name) { + this.styleAttr(type, key, name[key]) } + return this } var morpher = new Morphable(this._stepper).to(val) @@ -654,6 +675,8 @@ extend(Runner, { }, zoom (level, point) { + if (this._tryRetarget('zoom', to, point)) return this + var morpher = new Morphable(this._stepper).to(new SVGNumber(level)) this.queue(function () { @@ -661,6 +684,9 @@ extend(Runner, { }, function (pos) { this.element().zoom(morpher.at(pos), point) return morpher.done() + }, function (newLevel, newPoint) { + point = newPoint + morpher.to(newLevel) }) return this @@ -714,7 +740,7 @@ extend(Runner, { startTransform = new Matrix(relative ? undefined : element) // add the runner to the element so it can merge transformations - element.addRunner(this) + element._addRunner(this) // Deactivate all transforms that have run so far if we are absolute if (!relative) { @@ -953,3 +979,4 @@ extend(Runner, { }) extend(Runner, { rx, ry, from, to }) +register(Runner) diff --git a/src/animation/Timeline.js b/src/animation/Timeline.js index c3ad07c..44b5261 100644 --- a/src/animation/Timeline.js +++ b/src/animation/Timeline.js @@ -80,11 +80,12 @@ export default class Timeline extends EventTarget { // Manage runner runner.unschedule() runner.timeline(this) - // runner.time(-delay) + + const persist = runner.persist() // Save runnerInfo this._runners[runner.id] = { - persist: this.persist(), + persist: persist === null ? this._persist : persist, runner: runner, start: absoluteStartTime + delay } diff --git a/src/modules/core/attr.js b/src/modules/core/attr.js index 79dd0d7..548a6fb 100644 --- a/src/modules/core/attr.js +++ b/src/modules/core/attr.js @@ -30,7 +30,7 @@ export default function attr (attr, val, ns) { last[curr] = this.attr(curr) return last }, {}) - } else if (typeof attr === 'object') { + } else if (typeof attr === 'object' && attr.constructor === Object) { // apply every attribute individually if an object is passed for (val in attr) this.attr(val, attr[val]) } else if (val === null) { diff --git a/src/types/Box.js b/src/types/Box.js index d2ddcdd..3df1367 100644 --- a/src/types/Box.js +++ b/src/types/Box.js @@ -1,6 +1,7 @@ import { delimiter } from '../modules/core/regex.js' -import { registerMethods } from '../utils/methods.js' import { globals } from '../utils/window.js' +import { register } from '../utils/adopter.js' +import { registerMethods } from '../utils/methods.js' import Point from './Point.js' import parser from '../modules/core/parser.js' @@ -152,3 +153,5 @@ registerMethods({ } } }) + +register(Box) diff --git a/src/types/Color.js b/src/types/Color.js index a1329aa..93ca570 100644 --- a/src/types/Color.js +++ b/src/types/Color.js @@ -63,6 +63,9 @@ export default class Color { } init (a = 0, b = 0, c = 0, d = 0, space = 'rgb') { + // This catches the case when a falsy value is passed like '' + a = !a ? 0 : a + // Reset all values in case the init function is rerun with new color space if (this.space) { for (let component in this.space) { diff --git a/src/types/EventTarget.js b/src/types/EventTarget.js index 5a005fd..d414dd8 100644 --- a/src/types/EventTarget.js +++ b/src/types/EventTarget.js @@ -1,4 +1,5 @@ import { dispatch, off, on } from '../modules/core/event.js' +import { register } from '../utils/adopter.js' import Base from './Base.js' export default class EventTarget extends Base { @@ -56,3 +57,5 @@ export default class EventTarget extends Base { removeEventListener () {} } + +register(EventTarget) diff --git a/src/types/List.js b/src/types/List.js index 44f0fed..f66e3cd 100644 --- a/src/types/List.js +++ b/src/types/List.js @@ -13,16 +13,14 @@ export default List extend(List, { each (fnOrMethodName, ...args) { if (typeof fnOrMethodName === 'function') { - this.forEach((el) => { - fnOrMethodName.call(el, el) + return this.map((el) => { + return fnOrMethodName.call(el, el) }) } else { return this.map(el => { return el[fnOrMethodName](...args) }) } - - return this }, toArray () { diff --git a/src/types/Matrix.js b/src/types/Matrix.js index 102192b..ef90ca3 100644 --- a/src/types/Matrix.js +++ b/src/types/Matrix.js @@ -1,5 +1,6 @@ import { delimiter } from '../modules/core/regex.js' import { radians } from '../utils/utils.js' +import { register } from '../utils/adopter.js' import Element from '../elements/Element.js' import Point from './Point.js' @@ -498,3 +499,5 @@ export function screenCTM () { } return new Matrix(this.node.getScreenCTM()) } + +register(Matrix) |