aboutsummaryrefslogtreecommitdiffstats
path: root/extlib/leaflet/src/layer/marker/Marker.js
diff options
context:
space:
mode:
Diffstat (limited to 'extlib/leaflet/src/layer/marker/Marker.js')
-rw-r--r--extlib/leaflet/src/layer/marker/Marker.js123
1 files changed, 123 insertions, 0 deletions
diff --git a/extlib/leaflet/src/layer/marker/Marker.js b/extlib/leaflet/src/layer/marker/Marker.js
new file mode 100644
index 00000000..b98bec4e
--- /dev/null
+++ b/extlib/leaflet/src/layer/marker/Marker.js
@@ -0,0 +1,123 @@
+/*
+ * L.Marker is used to display clickable/draggable icons on the map.
+ */
+
+L.Marker = L.Class.extend({
+
+ includes: L.Mixin.Events,
+
+ options: {
+ icon: new L.Icon(),
+ title: '',
+ clickable: true,
+ draggable: false
+ },
+
+ initialize: function(latlng, options) {
+ L.Util.setOptions(this, options);
+ this._latlng = latlng;
+ },
+
+ onAdd: function(map) {
+ this._map = map;
+
+ this._initIcon();
+
+ map.on('viewreset', this._reset, this);
+ this._reset();
+ },
+
+ onRemove: function(map) {
+ this._removeIcon();
+
+ map.off('viewreset', this._reset, this);
+ },
+
+ getLatLng: function() {
+ return this._latlng;
+ },
+
+ setLatLng: function(latlng) {
+ this._latlng = latlng;
+ this._reset();
+ },
+
+ setIcon: function(icon) {
+ this._removeIcon();
+
+ this._icon = this._shadow = null;
+ this.options.icon = icon;
+
+ this._initIcon();
+ },
+
+ _initIcon: function() {
+ if (!this._icon) {
+ this._icon = this.options.icon.createIcon();
+
+ if (this.options.title) {
+ this._icon.title = this.options.title;
+ }
+
+ this._initInteraction();
+ }
+ if (!this._shadow) {
+ this._shadow = this.options.icon.createShadow();
+ }
+
+ this._map._panes.markerPane.appendChild(this._icon);
+ if (this._shadow) {
+ this._map._panes.shadowPane.appendChild(this._shadow);
+ }
+ },
+
+ _removeIcon: function() {
+ this._map._panes.markerPane.removeChild(this._icon);
+ if (this._shadow) {
+ this._map._panes.shadowPane.removeChild(this._shadow);
+ }
+ },
+
+ _reset: function() {
+ var pos = this._map.latLngToLayerPoint(this._latlng).round();
+
+ L.DomUtil.setPosition(this._icon, pos);
+ if (this._shadow) {
+ L.DomUtil.setPosition(this._shadow, pos);
+ }
+
+ this._icon.style.zIndex = pos.y;
+ },
+
+ _initInteraction: function() {
+ if (this.options.clickable) {
+ this._icon.className += ' leaflet-clickable';
+
+ L.DomEvent.addListener(this._icon, 'click', this._onMouseClick, this);
+
+ var events = ['dblclick', 'mousedown', 'mouseover', 'mouseout'];
+ for (var i = 0; i < events.length; i++) {
+ L.DomEvent.addListener(this._icon, events[i], this._fireMouseEvent, this);
+ }
+ }
+
+ if (L.Handler.MarkerDrag) {
+ this.dragging = new L.Handler.MarkerDrag(this);
+
+ if (this.options.draggable) {
+ this.dragging.enable();
+ }
+ }
+ },
+
+ _onMouseClick: function(e) {
+ L.DomEvent.stopPropagation(e);
+ if (this.dragging && this.dragging.moved()) { return; }
+ this.fire(e.type);
+ },
+
+ _fireMouseEvent: function(e) {
+ this.fire(e.type);
+ L.DomEvent.stopPropagation(e);
+ }
+}); \ No newline at end of file