summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorwout <wout@impinc.co.uk>2014-02-01 20:13:05 +0100
committerwout <wout@impinc.co.uk>2014-02-01 20:13:05 +0100
commit11376f6ec53092bd3893a168f25a08983d7aff6c (patch)
treede6a4725bb791549a3e177ec06b0364e913f5659 /src
parenta19bbab549b2d65b83751c3ef85295ee02065f42 (diff)
downloadsvg.js-11376f6ec53092bd3893a168f25a08983d7aff6c.tar.gz
svg.js-11376f6ec53092bd3893a168f25a08983d7aff6c.zip
added `morph()` and `at()` methods to `SVG.Number` for unit morphing
Diffstat (limited to 'src')
-rwxr-xr-xsrc/color.js2
-rwxr-xr-xsrc/element.js4
-rwxr-xr-xsrc/fx.js69
-rwxr-xr-xsrc/group.js9
-rwxr-xr-xsrc/number.js31
5 files changed, 64 insertions, 51 deletions
diff --git a/src/color.js b/src/color.js
index d870d5f..e73d7e0 100755
--- a/src/color.js
+++ b/src/color.js
@@ -74,7 +74,7 @@ SVG.extend(SVG.Color, {
/* normalise pos */
pos = pos < 0 ? 0 : pos > 1 ? 1 : pos
- /* generate morphed array */
+ /* generate morphed color */
return new SVG.Color({
r: ~~(this.r + (this.destination.r - this.r) * pos)
, g: ~~(this.g + (this.destination.g - this.g) * pos)
diff --git a/src/element.js b/src/element.js
index 50edc85..b75ed32 100755
--- a/src/element.js
+++ b/src/element.js
@@ -39,11 +39,11 @@ SVG.extend(SVG.Element, {
}
// Move by center over x-axis
, cx: function(x) {
- return x == null ? this.bbox().cx : this.x(x - this.bbox().width / 2)
+ return x == null ? this.x() + this.width() / 2 : this.x(x - this.width() / 2)
}
// Move by center over y-axis
, cy: function(y) {
- return y == null ? this.bbox().cy : this.y(y - this.bbox().height / 2)
+ return y == null ? this.y() + this.height() / 2 : this.y(y - this.height() / 2)
}
// Move element to given x and y values
, move: function(x, y) {
diff --git a/src/fx.js b/src/fx.js
index c6bef96..40f253b 100755
--- a/src/fx.js
+++ b/src/fx.js
@@ -3,7 +3,6 @@ SVG.FX = function(element) {
this.target = element
}
-//
SVG.extend(SVG.FX, {
// Add animation parameters and start animation
animate: function(d, ease, delay) {
@@ -98,46 +97,46 @@ SVG.extend(SVG.FX, {
} else {
/* run all x-position properties */
if (fx._x)
- element.x(fx._at(fx._x, pos))
+ element.x(at(fx._x, pos))
else if (fx._cx)
- element.cx(fx._at(fx._cx, pos))
+ element.cx(at(fx._cx, pos))
/* run all y-position properties */
if (fx._y)
- element.y(fx._at(fx._y, pos))
+ element.y(at(fx._y, pos))
else if (fx._cy)
- element.cy(fx._at(fx._cy, pos))
+ element.cy(at(fx._cy, pos))
/* run all size properties */
if (fx._size)
- element.size(fx._at(fx._size.width, pos), fx._at(fx._size.height, pos))
+ element.size(at(fx._size.width, pos), at(fx._size.height, pos))
}
/* run all viewbox properties */
if (fx._viewbox)
element.viewbox(
- fx._at(fx._viewbox.x, pos)
- , fx._at(fx._viewbox.y, pos)
- , fx._at(fx._viewbox.width, pos)
- , fx._at(fx._viewbox.height, pos)
+ at(fx._viewbox.x, pos)
+ , at(fx._viewbox.y, pos)
+ , at(fx._viewbox.width, pos)
+ , at(fx._viewbox.height, pos)
)
/* animate attributes */
for (i = akeys.length - 1; i >= 0; i--)
- element.attr(akeys[i], fx._at(fx.attrs[akeys[i]], pos))
+ element.attr(akeys[i], at(fx.attrs[akeys[i]], pos))
/* animate transformations */
for (i = tkeys.length - 1; i >= 0; i--)
- element.transform(tkeys[i], fx._at(fx.trans[tkeys[i]], pos))
+ element.transform(tkeys[i], at(fx.trans[tkeys[i]], pos))
/* animate styles */
for (i = skeys.length - 1; i >= 0; i--)
- element.style(skeys[i], fx._at(fx.styles[skeys[i]], pos))
+ element.style(skeys[i], at(fx.styles[skeys[i]], pos))
/* callback for each keyframe */
if (fx._during)
fx._during.call(element, pos, function(from, to) {
- return fx._at({ from: from, to: to }, pos)
+ return at({ from: from, to: to }, pos)
})
}
@@ -201,7 +200,7 @@ SVG.extend(SVG.FX, {
return this.target.bbox()
}
// Add animatable attributes
-, attr: function(a, v, n) {
+, attr: function(a, v) {
if (typeof a == 'object') {
for (var key in a)
this.attr(key, a[key])
@@ -211,6 +210,8 @@ SVG.extend(SVG.FX, {
this.attrs[a] = SVG.Color.isColor(from) ?
new SVG.Color(from).morph(v) :
+ SVG.regex.unit.test(from) ?
+ new SVG.Number(from).morph(v) :
{ from: from, to: v }
}
@@ -395,29 +396,9 @@ SVG.extend(SVG.FX, {
return this
}
- // Private: calculate position according to from and to
-, _at: function(o, pos) {
- /* number recalculation */
- return typeof o.from == 'number' ?
- o.from + (o.to - o.from) * pos :
-
- /* unit recalculation */
- SVG.regex.unit.test(o.to) ?
- new SVG.Number(o.to)
- .minus(new SVG.Number(o.from))
- .times(pos)
- .plus(new SVG.Number(o.from)) :
-
- /* color recalculation */
- o instanceof SVG.Color ? o.at(pos) :
-
- /* for all other values wait until pos has reached 1 to return the final value */
- pos < 1 ? o.from : o.to
- }
})
-//
SVG.extend(SVG.Element, {
// Get fx module or create a new one, then animate with given duration and ease
animate: function(d, ease, delay) {
@@ -444,15 +425,21 @@ SVG.extend(SVG.Element, {
return this
}
-
})
-// Usage:
-
-// rect.animate(1500, '>').move(200, 300).after(function() {
-// this.fill({ color: '#f06' })
-// })
+// Calculate position according to from and to
+function at(o, pos) {
+ /* number recalculation (don't bother converting to SVG.Number for performance reasons) */
+ return typeof o.from == 'number' ?
+ o.from + (o.to - o.from) * pos :
+
+ /* instance recalculation */
+ o instanceof SVG.Color || o instanceof SVG.Number ? o.at(pos) :
+
+ /* for all other values wait until pos has reached 1 to return the final value */
+ pos < 1 ? o.from : o.to
+}
// Shim layer with setTimeout fallback by Paul Irish
window.requestAnimFrame = (function(){
diff --git a/src/group.js b/src/group.js
index 84eed54..6f2d502 100755
--- a/src/group.js
+++ b/src/group.js
@@ -15,6 +15,15 @@ SVG.extend(SVG.G, {
, y: function(y) {
return y == null ? this.trans.y : this.transform('y', y)
}
+ // Move by center over x-axis
+, cx: function(x) {
+ return x == null ? this.bbox().cx : this.x(x - this.bbox().width / 2)
+ }
+ // Move by center over y-axis
+, cy: function(y) {
+ return y == null ? this.bbox().cy : this.y(y - this.bbox().height / 2)
+ }
+
})
//
diff --git a/src/number.js b/src/number.js
index 2b3b147..7218a50 100755
--- a/src/number.js
+++ b/src/number.js
@@ -45,13 +45,6 @@ SVG.extend(SVG.Number, {
valueOf: function() {
return this.value
}
- // Convert to different unit
-, to: function(unit) {
- if (typeof unit === 'string')
- this.unit = unit
-
- return this
- }
// Add number
, plus: function(number) {
this.value = this + new SVG.Number(number)
@@ -74,5 +67,29 @@ SVG.extend(SVG.Number, {
return this
}
+ // Convert to different unit
+, to: function(unit) {
+ if (typeof unit === 'string')
+ this.unit = unit
+
+ return this
+ }
+ // Make number morphable
+, morph: function(number) {
+ this.destination = new SVG.Number(number)
+
+ return this
+ }
+ // Get morphed number at given position
+, at: function(pos) {
+ /* make sure a destination is defined */
+ if (!this.destination) return this
+
+ /* generate morphed number */
+ return new SVG.Number(this.destination)
+ .minus(this)
+ .times(pos)
+ .plus(this)
+ }
}) \ No newline at end of file