leaflet-js 0.6.beta4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +15 -0
- data/CHANGELOG.rdoc +32 -0
- data/LICENSE +21 -0
- data/README.rdoc +54 -0
- data/Rakefile +15 -0
- data/leaflet-js.gemspec +28 -0
- data/lib/leaflet-js.rb +10 -0
- data/lib/leaflet.draw/BREAKINGCHANGES.md +54 -0
- data/lib/leaflet.draw/CHANGELOG.md +73 -0
- data/lib/leaflet.draw/Jakefile.js +26 -0
- data/lib/leaflet.draw/MIT-LICENCE.txt +20 -0
- data/lib/leaflet.draw/README.md +364 -0
- data/lib/leaflet.draw/TODO.md +62 -0
- data/lib/leaflet.draw/build/build.html +243 -0
- data/lib/leaflet.draw/build/build.js +189 -0
- data/lib/leaflet.draw/build/deps.js +75 -0
- data/lib/leaflet.draw/build/hintrc.js +47 -0
- data/lib/leaflet.draw/build/leaflet.draw-include.js +42 -0
- data/lib/leaflet.draw/dist/images/spritesheet.png +0 -0
- data/lib/leaflet.draw/dist/leaflet.draw-src.js +2429 -0
- data/lib/leaflet.draw/dist/leaflet.draw.css +212 -0
- data/lib/leaflet.draw/dist/leaflet.draw.ie.css +44 -0
- data/lib/leaflet.draw/dist/leaflet.draw.js +10 -0
- data/lib/leaflet.draw/examples/basic.html +106 -0
- data/lib/leaflet.draw/examples/edithandlers.html +67 -0
- data/lib/leaflet.draw/examples/libs/images/layers.png +0 -0
- data/lib/leaflet.draw/examples/libs/images/marker-icon.png +0 -0
- data/lib/leaflet.draw/examples/libs/images/marker-icon@2x.png +0 -0
- data/lib/leaflet.draw/examples/libs/images/marker-shadow.png +0 -0
- data/lib/leaflet.draw/examples/libs/leaflet-src.js +8587 -0
- data/lib/leaflet.draw/examples/libs/leaflet.css +459 -0
- data/lib/leaflet.draw/examples/libs/leaflet.ie.css +51 -0
- data/lib/leaflet.draw/package.json +37 -0
- data/lib/leaflet.draw/spec/after.js +2 -0
- data/lib/leaflet.draw/spec/before.js +3 -0
- data/lib/leaflet.draw/spec/expect.js +1253 -0
- data/lib/leaflet.draw/spec/happen.js +93 -0
- data/lib/leaflet.draw/spec/index.html +36 -0
- data/lib/leaflet.draw/spec/karma.conf.js +69 -0
- data/lib/leaflet.draw/spec/sinon.js +4223 -0
- data/lib/leaflet.draw/spec/suites/DrawControlSpec.js +15 -0
- data/lib/leaflet.draw/spec/suites/SpecHelper.js +26 -0
- data/lib/leaflet.draw/src/Control.Draw.js +101 -0
- data/lib/leaflet.draw/src/Leaflet.draw.js +5 -0
- data/lib/leaflet.draw/src/Toolbar.js +187 -0
- data/lib/leaflet.draw/src/Tooltip.js +52 -0
- data/lib/leaflet.draw/src/copyright.js +8 -0
- data/lib/leaflet.draw/src/draw/DrawToolbar.js +107 -0
- data/lib/leaflet.draw/src/draw/handler/Draw.Circle.js +59 -0
- data/lib/leaflet.draw/src/draw/handler/Draw.Feature.js +74 -0
- data/lib/leaflet.draw/src/draw/handler/Draw.Marker.js +97 -0
- data/lib/leaflet.draw/src/draw/handler/Draw.Polygon.js +79 -0
- data/lib/leaflet.draw/src/draw/handler/Draw.Polyline.js +360 -0
- data/lib/leaflet.draw/src/draw/handler/Draw.Rectangle.js +41 -0
- data/lib/leaflet.draw/src/draw/handler/Draw.SimpleShape.js +67 -0
- data/lib/leaflet.draw/src/edit/EditToolbar.js +93 -0
- data/lib/leaflet.draw/src/edit/handler/Edit.Circle.js +63 -0
- data/lib/leaflet.draw/src/edit/handler/Edit.Poly.js +267 -0
- data/lib/leaflet.draw/src/edit/handler/Edit.Rectangle.js +117 -0
- data/lib/leaflet.draw/src/edit/handler/Edit.SimpleShape.js +138 -0
- data/lib/leaflet.draw/src/edit/handler/EditToolbar.Delete.js +109 -0
- data/lib/leaflet.draw/src/edit/handler/EditToolbar.Edit.js +233 -0
- data/lib/leaflet.draw/src/ext/LatLngUtil.js +18 -0
- data/lib/leaflet.draw/src/ext/LineUtil.Intersect.js +15 -0
- data/lib/leaflet.draw/src/ext/Polygon.Intersect.js +27 -0
- data/lib/leaflet.draw/src/ext/Polyline.Intersect.js +85 -0
- data/lib/leaflet.label/CHANGELOG.md +35 -0
- data/lib/leaflet.label/Jakefile.js +21 -0
- data/lib/leaflet.label/MIT-LICENCE.txt +20 -0
- data/lib/leaflet.label/README.md +86 -0
- data/lib/leaflet.label/build/build.js +155 -0
- data/lib/leaflet.label/build/deps.js +24 -0
- data/lib/leaflet.label/build/hint.js +30 -0
- data/lib/leaflet.label/build/hintrc.js +47 -0
- data/lib/leaflet.label/dist/images/death.png +0 -0
- data/lib/leaflet.label/dist/leaflet.label-src.js +359 -0
- data/lib/leaflet.label/dist/leaflet.label.css +33 -0
- data/lib/leaflet.label/dist/leaflet.label.js +9 -0
- data/lib/leaflet.label/example/label.html +82 -0
- data/lib/leaflet.label/libs/leaflet/images/layers.png +0 -0
- data/lib/leaflet.label/libs/leaflet/images/marker-icon.png +0 -0
- data/lib/leaflet.label/libs/leaflet/images/marker-icon@2x.png +0 -0
- data/lib/leaflet.label/libs/leaflet/images/marker-shadow.png +0 -0
- data/lib/leaflet.label/libs/leaflet/leaflet-src.js +8587 -0
- data/lib/leaflet.label/libs/leaflet/leaflet.css +459 -0
- data/lib/leaflet.label/libs/leaflet/leaflet.ie.css +51 -0
- data/lib/leaflet.label/libs/leaflet/leaflet.js +8 -0
- data/lib/leaflet.label/src/FeatureGroup.Label.js +20 -0
- data/lib/leaflet.label/src/Label.js +123 -0
- data/lib/leaflet.label/src/Leaflet.label.js +5 -0
- data/lib/leaflet.label/src/Map.Label.js +7 -0
- data/lib/leaflet.label/src/Marker.Label.js +160 -0
- data/lib/leaflet.label/src/Path.Label.js +55 -0
- data/lib/leaflet.label/src/copyright.js +8 -0
- data/lib/leaflet/CHANGELOG.md +637 -0
- data/lib/leaflet/CONTRIBUTING.md +155 -0
- data/lib/leaflet/Jakefile.js +26 -0
- data/lib/leaflet/LICENSE +23 -0
- data/lib/leaflet/README.md +30 -0
- data/lib/leaflet/build/build.html +243 -0
- data/lib/leaflet/build/build.js +193 -0
- data/lib/leaflet/build/deps.js +256 -0
- data/lib/leaflet/build/hintrc.js +37 -0
- data/lib/leaflet/debug/css/mobile.css +6 -0
- data/lib/leaflet/debug/css/screen.css +5 -0
- data/lib/leaflet/debug/hacks/jitter.html +43 -0
- data/lib/leaflet/debug/leaflet-include.js +59 -0
- data/lib/leaflet/debug/map/canvas.html +47 -0
- data/lib/leaflet/debug/map/controls.html +50 -0
- data/lib/leaflet/debug/map/geolocation.html +35 -0
- data/lib/leaflet/debug/map/image-overlay.html +44 -0
- data/lib/leaflet/debug/map/map-mobile.html +35 -0
- data/lib/leaflet/debug/map/map.html +60 -0
- data/lib/leaflet/debug/map/max-bounds.html +37 -0
- data/lib/leaflet/debug/map/scroll.html +36 -0
- data/lib/leaflet/debug/map/simple-proj.html +45 -0
- data/lib/leaflet/debug/map/wms-marble.html +31 -0
- data/lib/leaflet/debug/map/wms.html +41 -0
- data/lib/leaflet/debug/map/zoomlevels.html +46 -0
- data/lib/leaflet/debug/tests/add_remove_layers.html +88 -0
- data/lib/leaflet/debug/tests/bringtoback.html +38 -0
- data/lib/leaflet/debug/tests/click_on_canvas.html +59 -0
- data/lib/leaflet/debug/tests/click_on_canvas_broken.html +49 -0
- data/lib/leaflet/debug/tests/opacity.html +57 -0
- data/lib/leaflet/debug/tests/remove_while_dragging.html +29 -0
- data/lib/leaflet/debug/tests/removetilewhilepan.html +42 -0
- data/lib/leaflet/debug/tests/reuse_popups.html +41 -0
- data/lib/leaflet/debug/tests/svg_clicks.html +55 -0
- data/lib/leaflet/debug/vector/bounds-extend.html +89 -0
- data/lib/leaflet/debug/vector/feature-group-bounds.html +91 -0
- data/lib/leaflet/debug/vector/geojson-sample.js +53 -0
- data/lib/leaflet/debug/vector/geojson.html +174 -0
- data/lib/leaflet/debug/vector/rectangle.html +54 -0
- data/lib/leaflet/debug/vector/route.js +1 -0
- data/lib/leaflet/debug/vector/touchzoomemu.html +195 -0
- data/lib/leaflet/debug/vector/us-states.js +54 -0
- data/lib/leaflet/debug/vector/vector-bounds.html +70 -0
- data/lib/leaflet/debug/vector/vector-canvas.html +93 -0
- data/lib/leaflet/debug/vector/vector-mobile.html +39 -0
- data/lib/leaflet/debug/vector/vector-simple.html +49 -0
- data/lib/leaflet/debug/vector/vector.html +38 -0
- data/lib/leaflet/dist/images/layers.png +0 -0
- data/lib/leaflet/dist/images/marker-icon-2x.png +0 -0
- data/lib/leaflet/dist/images/marker-icon.png +0 -0
- data/lib/leaflet/dist/images/marker-shadow.png +0 -0
- data/lib/leaflet/dist/leaflet-src.js +8579 -0
- data/lib/leaflet/dist/leaflet.css +459 -0
- data/lib/leaflet/dist/leaflet.ie.css +51 -0
- data/lib/leaflet/dist/leaflet.js +8 -0
- data/lib/leaflet/package.json +22 -0
- data/lib/leaflet/spec/after.js +2 -0
- data/lib/leaflet/spec/before.js +3 -0
- data/lib/leaflet/spec/expect.js +1253 -0
- data/lib/leaflet/spec/happen.js +93 -0
- data/lib/leaflet/spec/index.html +78 -0
- data/lib/leaflet/spec/karma.conf.js +64 -0
- data/lib/leaflet/spec/sinon.js +4223 -0
- data/lib/leaflet/spec/suites/LeafletSpec.js +13 -0
- data/lib/leaflet/spec/suites/SpecHelper.js +26 -0
- data/lib/leaflet/spec/suites/control/Control.AttributionSpec.js +68 -0
- data/lib/leaflet/spec/suites/control/Control.LayersSpec.js +67 -0
- data/lib/leaflet/spec/suites/control/Control.ScaleSpec.js +6 -0
- data/lib/leaflet/spec/suites/core/ClassSpec.js +156 -0
- data/lib/leaflet/spec/suites/core/EventsSpec.js +336 -0
- data/lib/leaflet/spec/suites/core/UtilSpec.js +212 -0
- data/lib/leaflet/spec/suites/dom/DomEventSpec.js +102 -0
- data/lib/leaflet/spec/suites/dom/DomUtilSpec.js +89 -0
- data/lib/leaflet/spec/suites/geo/LatLngBoundsSpec.js +136 -0
- data/lib/leaflet/spec/suites/geo/LatLngSpec.js +118 -0
- data/lib/leaflet/spec/suites/geo/ProjectionSpec.js +47 -0
- data/lib/leaflet/spec/suites/geometry/BoundsSpec.js +87 -0
- data/lib/leaflet/spec/suites/geometry/LineUtilSpec.js +75 -0
- data/lib/leaflet/spec/suites/geometry/PointSpec.js +104 -0
- data/lib/leaflet/spec/suites/geometry/PolyUtilSpec.js +27 -0
- data/lib/leaflet/spec/suites/geometry/TransformationSpec.js +31 -0
- data/lib/leaflet/spec/suites/layer/FeatureGroupSpec.js +36 -0
- data/lib/leaflet/spec/suites/layer/GeoJSONSpec.js +86 -0
- data/lib/leaflet/spec/suites/layer/LayerGroupSpec.js +58 -0
- data/lib/leaflet/spec/suites/layer/PopupSpec.js +59 -0
- data/lib/leaflet/spec/suites/layer/TileLayerSpec.js +87 -0
- data/lib/leaflet/spec/suites/layer/vector/CircleMarkerSpec.js +53 -0
- data/lib/leaflet/spec/suites/layer/vector/CircleSpec.js +17 -0
- data/lib/leaflet/spec/suites/layer/vector/PolygonSpec.js +55 -0
- data/lib/leaflet/spec/suites/layer/vector/PolylineGeometrySpec.js +35 -0
- data/lib/leaflet/spec/suites/layer/vector/PolylineSpec.js +55 -0
- data/lib/leaflet/spec/suites/map/MapSpec.js +244 -0
- data/lib/leaflet/src/Leaflet.js +23 -0
- data/lib/leaflet/src/control/Control.Attribution.js +115 -0
- data/lib/leaflet/src/control/Control.Layers.js +243 -0
- data/lib/leaflet/src/control/Control.Scale.js +112 -0
- data/lib/leaflet/src/control/Control.Zoom.js +86 -0
- data/lib/leaflet/src/control/Control.js +107 -0
- data/lib/leaflet/src/copyright.js +4 -0
- data/lib/leaflet/src/core/Browser.js +96 -0
- data/lib/leaflet/src/core/Class.js +106 -0
- data/lib/leaflet/src/core/Events.js +174 -0
- data/lib/leaflet/src/core/Handler.js +28 -0
- data/lib/leaflet/src/core/Util.js +182 -0
- data/lib/leaflet/src/dom/DomEvent.DoubleTap.js +103 -0
- data/lib/leaflet/src/dom/DomEvent.MsTouch.js +146 -0
- data/lib/leaflet/src/dom/DomEvent.js +211 -0
- data/lib/leaflet/src/dom/DomUtil.js +239 -0
- data/lib/leaflet/src/dom/Draggable.js +198 -0
- data/lib/leaflet/src/dom/PosAnimation.Timer.js +67 -0
- data/lib/leaflet/src/dom/PosAnimation.js +83 -0
- data/lib/leaflet/src/geo/LatLng.js +88 -0
- data/lib/leaflet/src/geo/LatLngBounds.js +153 -0
- data/lib/leaflet/src/geo/crs/CRS.EPSG3395.js +14 -0
- data/lib/leaflet/src/geo/crs/CRS.EPSG3857.js +21 -0
- data/lib/leaflet/src/geo/crs/CRS.EPSG4326.js +10 -0
- data/lib/leaflet/src/geo/crs/CRS.Simple.js +12 -0
- data/lib/leaflet/src/geo/crs/CRS.js +27 -0
- data/lib/leaflet/src/geo/projection/Projection.LonLat.js +13 -0
- data/lib/leaflet/src/geo/projection/Projection.Mercator.js +56 -0
- data/lib/leaflet/src/geo/projection/Projection.SphericalMercator.js +27 -0
- data/lib/leaflet/src/geo/projection/Projection.js +5 -0
- data/lib/leaflet/src/geometry/Bounds.js +95 -0
- data/lib/leaflet/src/geometry/LineUtil.js +202 -0
- data/lib/leaflet/src/geometry/Point.js +119 -0
- data/lib/leaflet/src/geometry/PolyUtil.js +55 -0
- data/lib/leaflet/src/geometry/Transformation.js +31 -0
- data/lib/leaflet/src/images/marker.svg +1 -0
- data/lib/leaflet/src/layer/FeatureGroup.js +81 -0
- data/lib/leaflet/src/layer/GeoJSON.js +245 -0
- data/lib/leaflet/src/layer/ImageOverlay.js +132 -0
- data/lib/leaflet/src/layer/LayerGroup.js +110 -0
- data/lib/leaflet/src/layer/Popup.js +316 -0
- data/lib/leaflet/src/layer/marker/DivIcon.js +43 -0
- data/lib/leaflet/src/layer/marker/Icon.Default.js +51 -0
- data/lib/leaflet/src/layer/marker/Icon.js +101 -0
- data/lib/leaflet/src/layer/marker/Marker.Drag.js +66 -0
- data/lib/leaflet/src/layer/marker/Marker.Popup.js +72 -0
- data/lib/leaflet/src/layer/marker/Marker.js +275 -0
- data/lib/leaflet/src/layer/tile/TileLayer.Anim.js +117 -0
- data/lib/leaflet/src/layer/tile/TileLayer.Canvas.js +60 -0
- data/lib/leaflet/src/layer/tile/TileLayer.WMS.js +83 -0
- data/lib/leaflet/src/layer/tile/TileLayer.js +578 -0
- data/lib/leaflet/src/layer/vector/Circle.js +98 -0
- data/lib/leaflet/src/layer/vector/CircleMarker.js +33 -0
- data/lib/leaflet/src/layer/vector/MultiPoly.js +47 -0
- data/lib/leaflet/src/layer/vector/Path.Popup.js +65 -0
- data/lib/leaflet/src/layer/vector/Path.SVG.js +219 -0
- data/lib/leaflet/src/layer/vector/Path.VML.js +125 -0
- data/lib/leaflet/src/layer/vector/Path.js +115 -0
- data/lib/leaflet/src/layer/vector/Polygon.js +81 -0
- data/lib/leaflet/src/layer/vector/Polyline.js +164 -0
- data/lib/leaflet/src/layer/vector/Rectangle.js +27 -0
- data/lib/leaflet/src/layer/vector/canvas/Circle.Canvas.js +18 -0
- data/lib/leaflet/src/layer/vector/canvas/Path.Canvas.js +196 -0
- data/lib/leaflet/src/layer/vector/canvas/Polygon.Canvas.js +37 -0
- data/lib/leaflet/src/layer/vector/canvas/Polyline.Canvas.js +30 -0
- data/lib/leaflet/src/map/Map.js +743 -0
- data/lib/leaflet/src/map/anim/Map.PanAnimation.js +88 -0
- data/lib/leaflet/src/map/anim/Map.ZoomAnimation.js +90 -0
- data/lib/leaflet/src/map/ext/Map.Geolocation.js +91 -0
- data/lib/leaflet/src/map/handler/Map.BoxZoom.js +104 -0
- data/lib/leaflet/src/map/handler/Map.DoubleClickZoom.js +23 -0
- data/lib/leaflet/src/map/handler/Map.Drag.js +146 -0
- data/lib/leaflet/src/map/handler/Map.Keyboard.js +147 -0
- data/lib/leaflet/src/map/handler/Map.ScrollWheelZoom.js +56 -0
- data/lib/leaflet/src/map/handler/Map.TouchZoom.js +121 -0
- data/vendor/assets/images/layers.png +0 -0
- data/vendor/assets/images/marker-icon-2x.png +0 -0
- data/vendor/assets/images/marker-icon.png +0 -0
- data/vendor/assets/images/marker-shadow.png +0 -0
- data/vendor/assets/images/spritesheet.png +0 -0
- data/vendor/assets/javascripts/leaflet.draw.js +39 -0
- data/vendor/assets/javascripts/leaflet.js +145 -0
- data/vendor/assets/javascripts/leaflet.label.js +9 -0
- data/vendor/assets/stylesheets/leaflet.css.erb +459 -0
- data/vendor/assets/stylesheets/leaflet.draw.css.erb +212 -0
- data/vendor/assets/stylesheets/leaflet.draw.ie.css +44 -0
- data/vendor/assets/stylesheets/leaflet.ie.css +51 -0
- data/vendor/assets/stylesheets/leaflet.label.css +33 -0
- metadata +317 -0
@@ -0,0 +1,98 @@
|
|
1
|
+
/*
|
2
|
+
* L.Circle is a circle overlay (with a certain radius in meters).
|
3
|
+
*/
|
4
|
+
|
5
|
+
L.Circle = L.Path.extend({
|
6
|
+
initialize: function (latlng, radius, options) {
|
7
|
+
L.Path.prototype.initialize.call(this, options);
|
8
|
+
|
9
|
+
this._latlng = L.latLng(latlng);
|
10
|
+
this._mRadius = radius;
|
11
|
+
},
|
12
|
+
|
13
|
+
options: {
|
14
|
+
fill: true
|
15
|
+
},
|
16
|
+
|
17
|
+
setLatLng: function (latlng) {
|
18
|
+
this._latlng = L.latLng(latlng);
|
19
|
+
return this.redraw();
|
20
|
+
},
|
21
|
+
|
22
|
+
setRadius: function (radius) {
|
23
|
+
this._mRadius = radius;
|
24
|
+
return this.redraw();
|
25
|
+
},
|
26
|
+
|
27
|
+
projectLatlngs: function () {
|
28
|
+
var lngRadius = this._getLngRadius(),
|
29
|
+
latlng = this._latlng,
|
30
|
+
pointLeft = this._map.latLngToLayerPoint([latlng.lat, latlng.lng - lngRadius]);
|
31
|
+
|
32
|
+
this._point = this._map.latLngToLayerPoint(latlng);
|
33
|
+
this._radius = Math.max(this._point.x - pointLeft.x, 1);
|
34
|
+
},
|
35
|
+
|
36
|
+
getBounds: function () {
|
37
|
+
var lngRadius = this._getLngRadius(),
|
38
|
+
latRadius = (this._mRadius / 40075017) * 360,
|
39
|
+
latlng = this._latlng;
|
40
|
+
|
41
|
+
return new L.LatLngBounds(
|
42
|
+
[latlng.lat - latRadius, latlng.lng - lngRadius],
|
43
|
+
[latlng.lat + latRadius, latlng.lng + lngRadius]);
|
44
|
+
},
|
45
|
+
|
46
|
+
getLatLng: function () {
|
47
|
+
return this._latlng;
|
48
|
+
},
|
49
|
+
|
50
|
+
getPathString: function () {
|
51
|
+
var p = this._point,
|
52
|
+
r = this._radius;
|
53
|
+
|
54
|
+
if (this._checkIfEmpty()) {
|
55
|
+
return '';
|
56
|
+
}
|
57
|
+
|
58
|
+
if (L.Browser.svg) {
|
59
|
+
return 'M' + p.x + ',' + (p.y - r) +
|
60
|
+
'A' + r + ',' + r + ',0,1,1,' +
|
61
|
+
(p.x - 0.1) + ',' + (p.y - r) + ' z';
|
62
|
+
} else {
|
63
|
+
p._round();
|
64
|
+
r = Math.round(r);
|
65
|
+
return 'AL ' + p.x + ',' + p.y + ' ' + r + ',' + r + ' 0,' + (65535 * 360);
|
66
|
+
}
|
67
|
+
},
|
68
|
+
|
69
|
+
getRadius: function () {
|
70
|
+
return this._mRadius;
|
71
|
+
},
|
72
|
+
|
73
|
+
// TODO Earth hardcoded, move into projection code!
|
74
|
+
|
75
|
+
_getLatRadius: function () {
|
76
|
+
return (this._mRadius / 40075017) * 360;
|
77
|
+
},
|
78
|
+
|
79
|
+
_getLngRadius: function () {
|
80
|
+
return this._getLatRadius() / Math.cos(L.LatLng.DEG_TO_RAD * this._latlng.lat);
|
81
|
+
},
|
82
|
+
|
83
|
+
_checkIfEmpty: function () {
|
84
|
+
if (!this._map) {
|
85
|
+
return false;
|
86
|
+
}
|
87
|
+
var vp = this._map._pathViewport,
|
88
|
+
r = this._radius,
|
89
|
+
p = this._point;
|
90
|
+
|
91
|
+
return p.x - r > vp.max.x || p.y - r > vp.max.y ||
|
92
|
+
p.x + r < vp.min.x || p.y + r < vp.min.y;
|
93
|
+
}
|
94
|
+
});
|
95
|
+
|
96
|
+
L.circle = function (latlng, radius, options) {
|
97
|
+
return new L.Circle(latlng, radius, options);
|
98
|
+
};
|
@@ -0,0 +1,33 @@
|
|
1
|
+
/*
|
2
|
+
* L.CircleMarker is a circle overlay with a permanent pixel radius.
|
3
|
+
*/
|
4
|
+
|
5
|
+
L.CircleMarker = L.Circle.extend({
|
6
|
+
options: {
|
7
|
+
radius: 10,
|
8
|
+
weight: 2
|
9
|
+
},
|
10
|
+
|
11
|
+
initialize: function (latlng, options) {
|
12
|
+
L.Circle.prototype.initialize.call(this, latlng, null, options);
|
13
|
+
this._radius = this.options.radius;
|
14
|
+
},
|
15
|
+
|
16
|
+
projectLatlngs: function () {
|
17
|
+
this._point = this._map.latLngToLayerPoint(this._latlng);
|
18
|
+
},
|
19
|
+
|
20
|
+
_updateStyle : function () {
|
21
|
+
L.Circle.prototype._updateStyle.call(this);
|
22
|
+
this.setRadius(this.options.radius);
|
23
|
+
},
|
24
|
+
|
25
|
+
setRadius: function (radius) {
|
26
|
+
this.options.radius = this._radius = radius;
|
27
|
+
return this.redraw();
|
28
|
+
}
|
29
|
+
});
|
30
|
+
|
31
|
+
L.circleMarker = function (latlng, options) {
|
32
|
+
return new L.CircleMarker(latlng, options);
|
33
|
+
};
|
@@ -0,0 +1,47 @@
|
|
1
|
+
/*
|
2
|
+
* Contains L.MultiPolyline and L.MultiPolygon layers.
|
3
|
+
*/
|
4
|
+
|
5
|
+
(function () {
|
6
|
+
function createMulti(Klass) {
|
7
|
+
|
8
|
+
return L.FeatureGroup.extend({
|
9
|
+
|
10
|
+
initialize: function (latlngs, options) {
|
11
|
+
this._layers = {};
|
12
|
+
this._options = options;
|
13
|
+
this.setLatLngs(latlngs);
|
14
|
+
},
|
15
|
+
|
16
|
+
setLatLngs: function (latlngs) {
|
17
|
+
var i = 0,
|
18
|
+
len = latlngs.length;
|
19
|
+
|
20
|
+
this.eachLayer(function (layer) {
|
21
|
+
if (i < len) {
|
22
|
+
layer.setLatLngs(latlngs[i++]);
|
23
|
+
} else {
|
24
|
+
this.removeLayer(layer);
|
25
|
+
}
|
26
|
+
}, this);
|
27
|
+
|
28
|
+
while (i < len) {
|
29
|
+
this.addLayer(new Klass(latlngs[i++], this._options));
|
30
|
+
}
|
31
|
+
|
32
|
+
return this;
|
33
|
+
}
|
34
|
+
});
|
35
|
+
}
|
36
|
+
|
37
|
+
L.MultiPolyline = createMulti(L.Polyline);
|
38
|
+
L.MultiPolygon = createMulti(L.Polygon);
|
39
|
+
|
40
|
+
L.multiPolyline = function (latlngs, options) {
|
41
|
+
return new L.MultiPolyline(latlngs, options);
|
42
|
+
};
|
43
|
+
|
44
|
+
L.multiPolygon = function (latlngs, options) {
|
45
|
+
return new L.MultiPolygon(latlngs, options);
|
46
|
+
};
|
47
|
+
}());
|
@@ -0,0 +1,65 @@
|
|
1
|
+
/*
|
2
|
+
* Popup extension to L.Path (polylines, polygons, circles), adding popup-related methods.
|
3
|
+
*/
|
4
|
+
|
5
|
+
L.Path.include({
|
6
|
+
|
7
|
+
bindPopup: function (content, options) {
|
8
|
+
|
9
|
+
if (content instanceof L.Popup) {
|
10
|
+
this._popup = content;
|
11
|
+
} else {
|
12
|
+
if (!this._popup || options) {
|
13
|
+
this._popup = new L.Popup(options, this);
|
14
|
+
}
|
15
|
+
this._popup.setContent(content);
|
16
|
+
}
|
17
|
+
|
18
|
+
if (!this._popupHandlersAdded) {
|
19
|
+
this
|
20
|
+
.on('click', this._openPopup, this)
|
21
|
+
.on('remove', this.closePopup, this);
|
22
|
+
|
23
|
+
this._popupHandlersAdded = true;
|
24
|
+
}
|
25
|
+
|
26
|
+
return this;
|
27
|
+
},
|
28
|
+
|
29
|
+
unbindPopup: function () {
|
30
|
+
if (this._popup) {
|
31
|
+
this._popup = null;
|
32
|
+
this
|
33
|
+
.off('click', this._openPopup)
|
34
|
+
.off('remove', this.closePopup);
|
35
|
+
|
36
|
+
this._popupHandlersAdded = false;
|
37
|
+
}
|
38
|
+
return this;
|
39
|
+
},
|
40
|
+
|
41
|
+
openPopup: function (latlng) {
|
42
|
+
|
43
|
+
if (this._popup) {
|
44
|
+
// open the popup from one of the path's points if not specified
|
45
|
+
latlng = latlng || this._latlng ||
|
46
|
+
this._latlngs[Math.floor(this._latlngs.length / 2)];
|
47
|
+
|
48
|
+
this._openPopup({latlng: latlng});
|
49
|
+
}
|
50
|
+
|
51
|
+
return this;
|
52
|
+
},
|
53
|
+
|
54
|
+
closePopup: function () {
|
55
|
+
if (this._popup) {
|
56
|
+
this._popup._close();
|
57
|
+
}
|
58
|
+
return this;
|
59
|
+
},
|
60
|
+
|
61
|
+
_openPopup: function (e) {
|
62
|
+
this._popup.setLatLng(e.latlng);
|
63
|
+
this._map.openPopup(this._popup);
|
64
|
+
}
|
65
|
+
});
|
@@ -0,0 +1,219 @@
|
|
1
|
+
/*
|
2
|
+
* Extends L.Path with SVG-specific rendering code.
|
3
|
+
*/
|
4
|
+
|
5
|
+
L.Path.SVG_NS = 'http://www.w3.org/2000/svg';
|
6
|
+
|
7
|
+
L.Browser.svg = !!(document.createElementNS && document.createElementNS(L.Path.SVG_NS, 'svg').createSVGRect);
|
8
|
+
|
9
|
+
L.Path = L.Path.extend({
|
10
|
+
statics: {
|
11
|
+
SVG: L.Browser.svg
|
12
|
+
},
|
13
|
+
|
14
|
+
bringToFront: function () {
|
15
|
+
var root = this._map._pathRoot,
|
16
|
+
path = this._container;
|
17
|
+
|
18
|
+
if (path && root.lastChild !== path) {
|
19
|
+
root.appendChild(path);
|
20
|
+
}
|
21
|
+
return this;
|
22
|
+
},
|
23
|
+
|
24
|
+
bringToBack: function () {
|
25
|
+
var root = this._map._pathRoot,
|
26
|
+
path = this._container,
|
27
|
+
first = root.firstChild;
|
28
|
+
|
29
|
+
if (path && first !== path) {
|
30
|
+
root.insertBefore(path, first);
|
31
|
+
}
|
32
|
+
return this;
|
33
|
+
},
|
34
|
+
|
35
|
+
getPathString: function () {
|
36
|
+
// form path string here
|
37
|
+
},
|
38
|
+
|
39
|
+
_createElement: function (name) {
|
40
|
+
return document.createElementNS(L.Path.SVG_NS, name);
|
41
|
+
},
|
42
|
+
|
43
|
+
_initElements: function () {
|
44
|
+
this._map._initPathRoot();
|
45
|
+
this._initPath();
|
46
|
+
this._initStyle();
|
47
|
+
},
|
48
|
+
|
49
|
+
_initPath: function () {
|
50
|
+
this._container = this._createElement('g');
|
51
|
+
|
52
|
+
this._path = this._createElement('path');
|
53
|
+
this._container.appendChild(this._path);
|
54
|
+
},
|
55
|
+
|
56
|
+
_initStyle: function () {
|
57
|
+
if (this.options.stroke) {
|
58
|
+
this._path.setAttribute('stroke-linejoin', 'round');
|
59
|
+
this._path.setAttribute('stroke-linecap', 'round');
|
60
|
+
}
|
61
|
+
if (this.options.fill) {
|
62
|
+
this._path.setAttribute('fill-rule', 'evenodd');
|
63
|
+
}
|
64
|
+
if (this.options.pointerEvents) {
|
65
|
+
this._path.setAttribute('pointer-events', this.options.pointerEvents);
|
66
|
+
}
|
67
|
+
if (!this.options.clickable && !this.options.pointerEvents) {
|
68
|
+
this._path.setAttribute('pointer-events', 'none');
|
69
|
+
}
|
70
|
+
this._updateStyle();
|
71
|
+
},
|
72
|
+
|
73
|
+
_updateStyle: function () {
|
74
|
+
if (this.options.stroke) {
|
75
|
+
this._path.setAttribute('stroke', this.options.color);
|
76
|
+
this._path.setAttribute('stroke-opacity', this.options.opacity);
|
77
|
+
this._path.setAttribute('stroke-width', this.options.weight);
|
78
|
+
if (this.options.dashArray) {
|
79
|
+
this._path.setAttribute('stroke-dasharray', this.options.dashArray);
|
80
|
+
} else {
|
81
|
+
this._path.removeAttribute('stroke-dasharray');
|
82
|
+
}
|
83
|
+
} else {
|
84
|
+
this._path.setAttribute('stroke', 'none');
|
85
|
+
}
|
86
|
+
if (this.options.fill) {
|
87
|
+
this._path.setAttribute('fill', this.options.fillColor || this.options.color);
|
88
|
+
this._path.setAttribute('fill-opacity', this.options.fillOpacity);
|
89
|
+
} else {
|
90
|
+
this._path.setAttribute('fill', 'none');
|
91
|
+
}
|
92
|
+
},
|
93
|
+
|
94
|
+
_updatePath: function () {
|
95
|
+
var str = this.getPathString();
|
96
|
+
if (!str) {
|
97
|
+
// fix webkit empty string parsing bug
|
98
|
+
str = 'M0 0';
|
99
|
+
}
|
100
|
+
this._path.setAttribute('d', str);
|
101
|
+
},
|
102
|
+
|
103
|
+
// TODO remove duplication with L.Map
|
104
|
+
_initEvents: function () {
|
105
|
+
if (this.options.clickable) {
|
106
|
+
if (L.Browser.svg || !L.Browser.vml) {
|
107
|
+
this._path.setAttribute('class', 'leaflet-clickable');
|
108
|
+
}
|
109
|
+
|
110
|
+
L.DomEvent.on(this._container, 'click', this._onMouseClick, this);
|
111
|
+
|
112
|
+
var events = ['dblclick', 'mousedown', 'mouseover',
|
113
|
+
'mouseout', 'mousemove', 'contextmenu'];
|
114
|
+
for (var i = 0; i < events.length; i++) {
|
115
|
+
L.DomEvent.on(this._container, events[i], this._fireMouseEvent, this);
|
116
|
+
}
|
117
|
+
}
|
118
|
+
},
|
119
|
+
|
120
|
+
_onMouseClick: function (e) {
|
121
|
+
if (this._map.dragging && this._map.dragging.moved()) { return; }
|
122
|
+
|
123
|
+
this._fireMouseEvent(e);
|
124
|
+
},
|
125
|
+
|
126
|
+
_fireMouseEvent: function (e) {
|
127
|
+
if (!this.hasEventListeners(e.type)) { return; }
|
128
|
+
|
129
|
+
var map = this._map,
|
130
|
+
containerPoint = map.mouseEventToContainerPoint(e),
|
131
|
+
layerPoint = map.containerPointToLayerPoint(containerPoint),
|
132
|
+
latlng = map.layerPointToLatLng(layerPoint);
|
133
|
+
|
134
|
+
this.fire(e.type, {
|
135
|
+
latlng: latlng,
|
136
|
+
layerPoint: layerPoint,
|
137
|
+
containerPoint: containerPoint,
|
138
|
+
originalEvent: e
|
139
|
+
});
|
140
|
+
|
141
|
+
if (e.type === 'contextmenu') {
|
142
|
+
L.DomEvent.preventDefault(e);
|
143
|
+
}
|
144
|
+
if (e.type !== 'mousemove') {
|
145
|
+
L.DomEvent.stopPropagation(e);
|
146
|
+
}
|
147
|
+
}
|
148
|
+
});
|
149
|
+
|
150
|
+
L.Map.include({
|
151
|
+
_initPathRoot: function () {
|
152
|
+
if (!this._pathRoot) {
|
153
|
+
this._pathRoot = L.Path.prototype._createElement('svg');
|
154
|
+
this._panes.overlayPane.appendChild(this._pathRoot);
|
155
|
+
|
156
|
+
if (this.options.zoomAnimation && L.Browser.any3d) {
|
157
|
+
this._pathRoot.setAttribute('class', ' leaflet-zoom-animated');
|
158
|
+
|
159
|
+
this.on({
|
160
|
+
'zoomanim': this._animatePathZoom,
|
161
|
+
'zoomend': this._endPathZoom
|
162
|
+
});
|
163
|
+
} else {
|
164
|
+
this._pathRoot.setAttribute('class', ' leaflet-zoom-hide');
|
165
|
+
}
|
166
|
+
|
167
|
+
this.on('moveend', this._updateSvgViewport);
|
168
|
+
this._updateSvgViewport();
|
169
|
+
}
|
170
|
+
},
|
171
|
+
|
172
|
+
_animatePathZoom: function (e) {
|
173
|
+
var scale = this.getZoomScale(e.zoom),
|
174
|
+
offset = this._getCenterOffset(e.center)._multiplyBy(-scale)._add(this._pathViewport.min);
|
175
|
+
|
176
|
+
this._pathRoot.style[L.DomUtil.TRANSFORM] =
|
177
|
+
L.DomUtil.getTranslateString(offset) + ' scale(' + scale + ') ';
|
178
|
+
|
179
|
+
this._pathZooming = true;
|
180
|
+
},
|
181
|
+
|
182
|
+
_endPathZoom: function () {
|
183
|
+
this._pathZooming = false;
|
184
|
+
},
|
185
|
+
|
186
|
+
_updateSvgViewport: function () {
|
187
|
+
|
188
|
+
if (this._pathZooming) {
|
189
|
+
// Do not update SVGs while a zoom animation is going on otherwise the animation will break.
|
190
|
+
// When the zoom animation ends we will be updated again anyway
|
191
|
+
// This fixes the case where you do a momentum move and zoom while the move is still ongoing.
|
192
|
+
return;
|
193
|
+
}
|
194
|
+
|
195
|
+
this._updatePathViewport();
|
196
|
+
|
197
|
+
var vp = this._pathViewport,
|
198
|
+
min = vp.min,
|
199
|
+
max = vp.max,
|
200
|
+
width = max.x - min.x,
|
201
|
+
height = max.y - min.y,
|
202
|
+
root = this._pathRoot,
|
203
|
+
pane = this._panes.overlayPane;
|
204
|
+
|
205
|
+
// Hack to make flicker on drag end on mobile webkit less irritating
|
206
|
+
if (L.Browser.mobileWebkit) {
|
207
|
+
pane.removeChild(root);
|
208
|
+
}
|
209
|
+
|
210
|
+
L.DomUtil.setPosition(root, min);
|
211
|
+
root.setAttribute('width', width);
|
212
|
+
root.setAttribute('height', height);
|
213
|
+
root.setAttribute('viewBox', [min.x, min.y, width, height].join(' '));
|
214
|
+
|
215
|
+
if (L.Browser.mobileWebkit) {
|
216
|
+
pane.appendChild(root);
|
217
|
+
}
|
218
|
+
}
|
219
|
+
});
|