From 2a386747017ff2b11a983acc3585490c0a35beca Mon Sep 17 00:00:00 2001 From: Bart Waardenburg Date: Wed, 28 Jun 2017 11:12:41 +0200 Subject: [PATCH] Partial fix for issue #1 * Implemented (part of) the fix as @obi068 suggested * Fixed bugs introduce in commit 422b577; Initial initial PR#13 created by @BartWaardenburg should be re-reviewed such that it can be merged in Leaflet.PolylineOffset code --- leaflet.polylineoffset.js | 43 +++++++++++++++++++++++---------------- 1 file changed, 25 insertions(+), 18 deletions(-) diff --git a/leaflet.polylineoffset.js b/leaflet.polylineoffset.js index 3575e4f..2b73b8d 100644 --- a/leaflet.polylineoffset.js +++ b/leaflet.polylineoffset.js @@ -9,29 +9,34 @@ L.PolylineOffset = { throw new Error('Line should be defined by at least 2 points'); } - var a = points[0], b; + var a = points[0], b, xs ,ys, dist; var offsetAngle, segmentAngle; var offsetSegments = []; for(var i=1; i < l; i++) { b = points[i]; + xs = b.x - a.x; + ys = b.y - a.y; + dist = Math.sqrt(xs * xs + ys * ys); // angle in (-PI, PI] segmentAngle = Math.atan2(a.y - b.y, a.x - b.x); // angle in (-1.5 * PI, PI/2] offsetAngle = segmentAngle - Math.PI/2; // store offset point and other information to avoid recomputing it later - offsetSegments.push({ - angle: segmentAngle, - offsetAngle: offsetAngle, - distance: distance, - original: [a, b], - offset: [ - this.translatePoint(a, distance, offsetAngle), - this.translatePoint(b, distance, offsetAngle) - ] - }); - a = b; + if (dist > distance) { + offsetSegments.push({ + angle: segmentAngle, + offsetAngle: offsetAngle, + distance: distance, + original: [a, b], + offset: [ + this.translatePoint(a, distance, offsetAngle), + this.translatePoint(b, distance, offsetAngle) + ] + }); + a = b; + } } return offsetSegments; @@ -152,14 +157,16 @@ L.PolylineOffset = { var l = segments.length; var joinedPoints = []; var s1 = segments[0], s2 = segments[0]; - joinedPoints.push(s1.offset[0]); + if (s1 && s2) { + joinedPoints.push(s1.offset[0]); - for(var i=1; i