summaryrefslogtreecommitdiffstats
path: root/src/patharray.js
diff options
context:
space:
mode:
authorUlrich-Matthias Schäfer <ulima.ums@googlemail.com>2015-11-28 11:21:07 +0100
committerUlrich-Matthias Schäfer <ulima.ums@googlemail.com>2015-11-28 11:21:07 +0100
commitdd7cc2f5104d488b0ba85366e14fae57edb767b7 (patch)
treeb0c1f2907004eea964f187fd69df7a892ab99ee0 /src/patharray.js
parentb60aca845104c3517931eda73a0747a4a0b1687d (diff)
downloadsvg.js-dd7cc2f5104d488b0ba85366e14fae57edb767b7.tar.gz
svg.js-dd7cc2f5104d488b0ba85366e14fae57edb767b7.zip
fix leading point bug in path parsing (#416)
Diffstat (limited to 'src/patharray.js')
-rw-r--r--src/patharray.js33
1 files changed, 22 insertions, 11 deletions
diff --git a/src/patharray.js b/src/patharray.js
index 8def341..6bf7276 100644
--- a/src/patharray.js
+++ b/src/patharray.js
@@ -13,15 +13,15 @@ SVG.extend(SVG.PathArray, {
}
// Move path string
, move: function(x, y) {
- // get bounding box of current situation
+ // get bounding box of current situation
var box = this.bbox()
-
- // get relative offset
+
+ // get relative offset
x -= box.x
y -= box.y
if (!isNaN(x) && !isNaN(y)) {
- // move every point
+ // move every point
for (var l, i = this.value.length - 1; i >= 0; i--) {
l = this.value[i][0]
@@ -58,10 +58,10 @@ SVG.extend(SVG.PathArray, {
}
// Resize path string
, size: function(width, height) {
- // get bounding box of current situation
+ // get bounding box of current situation
var i, l, box = this.bbox()
- // recalculate position of all points according to new size
+ // recalculate position of all points according to new size
for (i = this.value.length - 1; i >= 0; i--) {
l = this.value[i][0]
@@ -87,11 +87,11 @@ SVG.extend(SVG.PathArray, {
}
} else if (l == 'A') {
- // resize radii
+ // resize radii
this.value[i][1] = (this.value[i][1] * width) / box.width
this.value[i][2] = (this.value[i][2] * height) / box.height
- // move position values
+ // move position values
this.value[i][6] = ((this.value[i][6] - box.x) * width) / box.width + box.x
this.value[i][7] = ((this.value[i][7] - box.y) * height) / box.height + box.y
}
@@ -127,7 +127,18 @@ SVG.extend(SVG.PathArray, {
return [].concat.apply(prev, curr)
}, [])
}
-
+
+ // at this place there could be parts like ['3.124.854.32'] because we could not determine the point as seperator till now
+ // we fix this elements in the next loop
+ for(i = 0; i < array.length; ++i){
+ if(array[i].indexOf('.') != array[i].lastIndexOf('.')){
+ var split = array[i].split('.') // split at the point
+ var first = [split.shift(), split.shift()].join('.') // join the first number together
+ array.splice.apply(array, [i, 1].concat(first, split.map(function(el){ return '.'+el }))) // add first and all other entries back to array
+ i += split.length // dont forget to update the index
+ }
+ }
+
// array now is an array containing all parts of a path e.g. ['M', '0', '0', 'L', '30', '30' ...]
var arr = []
@@ -217,9 +228,9 @@ SVG.extend(SVG.PathArray, {
arr.push(seg)
}while(array.length)
-
+
return arr
-
+
}
// Get bounding box of path
, bbox: function() {