aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/circle.js4
-rw-r--r--src/element.js14
-rw-r--r--src/sugar.js8
3 files changed, 17 insertions, 9 deletions
diff --git a/src/circle.js b/src/circle.js
index d1f2cdc..059813e 100644
--- a/src/circle.js
+++ b/src/circle.js
@@ -27,8 +27,8 @@ SVG.extend(SVG.Circle, {
var r = this.attrs.r || 0;
return this.attr({
- cx: (x || ((this.attrs.x || 0) + r)),
- cy: (y || ((this.attrs.y || 0) + r))
+ cx: x || (this.attrs.x || 0) + r,
+ cy: y || (this.attrs.y || 0) + r
});
}
diff --git a/src/element.js b/src/element.js
index 5a4d4ed..e849867 100644
--- a/src/element.js
+++ b/src/element.js
@@ -110,20 +110,18 @@ SVG.extend(SVG.Element, {
t.push('rotate(' + o.rotation + ',' + (o.cx != null ? o.cx : b.cx) + ',' + (o.cy != null ? o.cy : b.cy) + ')');
// add scale
- if (o.scaleX != 1 && o.scaleY != 1)
- t.push('scale(' + o.sx + ',' + o.sy + ')');
+ t.push('scale(' + o.scaleX + ',' + o.scaleY + ')');
// add skew on x axis
if (o.skewX != 0)
- t.push('skewX(' + x.skewX + ')');
+ t.push('skewX(' + o.skewX + ')');
// add skew on y axis
if (o.skewY != 0)
- t.push('skewY(' + x.skewY + ')')
+ t.push('skewY(' + o.skewY + ')')
// add translate
- if (o.x != 0 && o.y != 0)
- t.push('translate(' + o.x + ',' + o.y + ')');
+ t.push('translate(' + o.x + ',' + o.y + ')');
// add only te required transformations
return this.attr('transform', t.join(' '));
@@ -138,9 +136,11 @@ SVG.extend(SVG.Element, {
// include translations on x an y
x: b.x + this.trans.x,
y: b.y + this.trans.y,
+
// add the center
- cx: b.x + this.trans.x + b.width / 2,
+ cx: b.x + this.trans.x + b.width / 2,
cy: b.y + this.trans.y + b.height / 2,
+
// plain width and height
width: b.width,
height: b.height
diff --git a/src/sugar.js b/src/sugar.js
index bd8454d..10a8716 100644
--- a/src/sugar.js
+++ b/src/sugar.js
@@ -41,6 +41,14 @@ SVG.extend(SVG.Element, {
cx: x == null ? b.cx : x,
cy: y == null ? b.cx : y
});
+ },
+
+ // skew
+ skew: function(x, y) {
+ return this.transform({
+ skewX: x || 0,
+ skewY: y || 0
+ });
}
});