diff --git a/.gitignore b/.gitignore index 496ee2c..ddb3e36 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,2 @@ -.DS_Store \ No newline at end of file +.DS_Store +/nbproject diff --git a/src/AnimatedMarker.js b/src/AnimatedMarker.js index ab95e1f..7832e80 100644 --- a/src/AnimatedMarker.js +++ b/src/AnimatedMarker.js @@ -1,4 +1,5 @@ L.AnimatedMarker = L.Marker.extend({ + includes: L.Mixin.Events, options: { // meters distance: 200, @@ -6,8 +7,6 @@ L.AnimatedMarker = L.Marker.extend({ interval: 1000, // animate on add? autoStart: true, - // callback onend - onEnd: function(){}, clickable: false }, @@ -26,7 +25,7 @@ L.AnimatedMarker = L.Marker.extend({ for (i=1;i this.options.distance) { while (dist > this.options.distance) { cur = new L.LatLng(cur.lat + dLat, cur.lng + dLng); - dist = cur.distanceTo(next); + dist = this._distance(cur, next); chunkedLatLngs.push(cur); } } else { @@ -48,6 +47,7 @@ L.AnimatedMarker = L.Marker.extend({ onAdd: function (map) { L.Marker.prototype.onAdd.call(this, map); + this._map = map; // Start animating when added to the map if (this.options.autoStart) { @@ -62,7 +62,7 @@ L.AnimatedMarker = L.Marker.extend({ // Normalize the transition speed from vertex to vertex if (this._i < len) { - speed = this._latlngs[this._i-1].distanceTo(this._latlngs[this._i]) / this.options.distance * this.options.interval; + speed = this._distance(this._latlngs[this._i-1], this._latlngs[this._i]) / this.options.distance * this.options.interval; } // Only if CSS3 transitions are supported @@ -78,7 +78,9 @@ L.AnimatedMarker = L.Marker.extend({ // Queue up the animation to the next next vertex this._tid = setTimeout(function(){ if (self._i === len) { - self.options.onEnd.apply(self, Array.prototype.slice.call(arguments)); + if (self._icon) { self._icon.style[L.DomUtil.TRANSITION] = ''; } + if (self._shadow) { self._shadow.style[L.DomUtil.TRANSITION] = ''; } + self.fire('animationend'); } else { self.animate(); } @@ -108,6 +110,14 @@ L.AnimatedMarker = L.Marker.extend({ this.options.interval = 30; } this._i = 1; + }, + + _distance: function(cur, next) { + if (this._map.options.crs.distance) { + return this._map.options.crs.distance(cur, next); + } else { + return cur.distanceTo(next); + } } });