Commit b1c60797 by Dmitry Baranovskiy

Merge pull request #742 from unel/master

It needs some tweaking, I will fix it.
parents e5048b7f a2edf84f
...@@ -3866,11 +3866,13 @@ ...@@ -3866,11 +3866,13 @@
= (number) length. = (number) length.
\*/ \*/
elproto.getTotalLength = function () { elproto.getTotalLength = function () {
if (this.type != "path") {return;} var path = this.getPath(); if(!path){ return; }
if (this.node.getTotalLength) { if (this.node.getTotalLength) {
return this.node.getTotalLength(); return this.node.getTotalLength();
} }
return getTotalLength(this.attrs.path);
return getTotalLength(path);
}; };
/*\ /*\
* Element.getPointAtLength * Element.getPointAtLength
...@@ -3890,8 +3892,29 @@ ...@@ -3890,8 +3892,29 @@
o } o }
\*/ \*/
elproto.getPointAtLength = function (length) { elproto.getPointAtLength = function (length) {
if (this.type != "path") {return;} var path = this.getPath(); if(!path){ return; }
return getPointAtLength(this.attrs.path, length);
return getPointAtLength(path, length);
};
/*\
* Element.getPath
[ method ]
**
* Return path of element. Only works for element of "path" type and simple elements like "circle".
**
\*/
elproto.getPath = function() {
var path;
if (this.type === "path") {
path = this.attrs.path
} else if(R._getPath[this.type] instanceof Function) {
path = R._getPath[this.type](this);
}
return path;
}; };
/*\ /*\
* Element.getSubpath * Element.getSubpath
...@@ -3907,8 +3930,9 @@ ...@@ -3907,8 +3930,9 @@
= (string) pathstring for the segment = (string) pathstring for the segment
\*/ \*/
elproto.getSubpath = function (from, to) { elproto.getSubpath = function (from, to) {
if (this.type != "path") {return;} var path = this.getPath(); if(!path){ return; }
return R.getSubpath(this.attrs.path, from, to);
return R.getSubpath(path, from, to);
}; };
/*\ /*\
* Raphael.easing_formulas * Raphael.easing_formulas
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or sign in to comment