]> git.openstreetmap.org Git - rails.git/blob - vendor/assets/leaflet/leaflet.osm.js
Update to Leaflet 0.5
[rails.git] / vendor / assets / leaflet / leaflet.osm.js
1 L.OSM = {};
2
3 L.OSM.TileLayer = L.TileLayer.extend({
4   options: {
5     url: 'http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',
6     attribution: '© <a target="_parent" href="http://www.openstreetmap.org">OpenStreetMap</a> and contributors, under an <a target="_parent" href="http://www.openstreetmap.org/copyright">open license</a>'
7   },
8
9   initialize: function (options) {
10     options = L.Util.setOptions(this, options);
11     L.TileLayer.prototype.initialize.call(this, options.url);
12   }
13 });
14
15 L.OSM.Mapnik = L.OSM.TileLayer.extend({
16   options: {
17     url: 'http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png'
18   }
19 });
20
21 L.OSM.CycleMap = L.OSM.TileLayer.extend({
22   options: {
23     url: 'http://{s}.tile.opencyclemap.org/cycle/{z}/{x}/{y}.png'
24   }
25 });
26
27 L.OSM.TransportMap = L.OSM.TileLayer.extend({
28   options: {
29     url: 'http://{s}.tile2.opencyclemap.org/transport/{z}/{x}/{y}.png'
30   }
31 });
32
33 L.OSM.MapQuestOpen = L.OSM.TileLayer.extend({
34   options: {
35     url: 'http://otile{s}.mqcdn.com/tiles/1.0.0/osm/{z}/{x}/{y}.png',
36     subdomains: '1234',
37     attribution: "Tiles courtesy of <a href='http://www.mapquest.com/' target='_blank'>MapQuest</a> <img src='http://developer.mapquest.com/content/osm/mq_logo.png'>"
38   }
39 });
40
41 L.OSM.DataLayer = L.FeatureGroup.extend({
42   options: {
43     areaTags: ['area', 'building', 'leisure', 'tourism', 'ruins', 'historic', 'landuse', 'military', 'natural', 'sport'],
44     uninterestingTags: ['source', 'source_ref', 'source:ref', 'history', 'attribution', 'created_by', 'tiger:county', 'tiger:tlid', 'tiger:upload_uuid'],
45     styles: {}
46   },
47
48   initialize: function (xml, options) {
49     L.Util.setOptions(this, options);
50
51     L.FeatureGroup.prototype.initialize.call(this);
52
53     if (xml) {
54       this.addData(xml);
55     }
56   },
57
58   addData: function (features) {
59     if (!(features instanceof Array)) {
60       features = this.buildFeatures(features);
61     }
62
63     for (var i = 0; i < features.length; i++) {
64       var feature = features[i], layer;
65
66       if (feature.type === "node") {
67         layer = L.circleMarker(feature.latLng, this.options.styles.node);
68       } else {
69         var latLngs = new Array(feature.nodes.length);
70
71         for (var j = 0; j < feature.nodes.length; j++) {
72           latLngs[j] = feature.nodes[j].latLng;
73         }
74
75         if (this.isWayArea(feature)) {
76           latLngs.pop(); // Remove last == first.
77           layer = L.polygon(latLngs, this.options.styles.area);
78         } else {
79           layer = L.polyline(latLngs, this.options.styles.way);
80         }
81       }
82
83       layer.addTo(this);
84       layer.feature = feature;
85     }
86   },
87
88   buildFeatures: function (xml) {
89     var features = [],
90       nodes = L.OSM.getNodes(xml),
91       ways = L.OSM.getWays(xml, nodes);
92
93     for (var node_id in nodes) {
94       var node = nodes[node_id];
95       if (this.interestingNode(node, ways)) {
96         features.push(node);
97       }
98     }
99
100     for (var i = 0; i < ways.length; i++) {
101       var way = ways[i];
102       features.push(way);
103     }
104
105     return features;
106   },
107
108   isWayArea: function (way) {
109     if (way.nodes[0] != way.nodes[way.nodes.length - 1]) {
110       return false;
111     }
112
113     for (var key in way.tags) {
114       if (~this.options.areaTags.indexOf(key)) {
115         return true;
116       }
117     }
118
119     return false;
120   },
121
122   interestingNode: function (node, ways) {
123     var used = false;
124
125     for (var i = 0; i < ways.length; i++) {
126       if (ways[i].nodes.indexOf(node) >= 0) {
127         used = true;
128         break;
129       }
130     }
131
132     if (!used) {
133       return true;
134     }
135
136     for (var key in node.tags) {
137       if (this.options.uninterestingTags.indexOf(key) < 0) {
138         return true;
139       }
140     }
141
142     return false;
143   }
144 });
145
146 L.Util.extend(L.OSM, {
147   getNodes: function (xml) {
148     var result = {};
149
150     var nodes = xml.getElementsByTagName("node");
151     for (var i = 0; i < nodes.length; i++) {
152       var node = nodes[i], id = node.getAttribute("id");
153       result[id] = {
154         id: id,
155         type: "node",
156         latLng: L.latLng(node.getAttribute("lat"),
157                          node.getAttribute("lon"),
158                          true),
159         tags: this.getTags(node)
160       };
161     }
162
163     return result;
164   },
165
166   getWays: function (xml, nodes) {
167     var result = [];
168
169     var ways = xml.getElementsByTagName("way");
170     for (var i = 0; i < ways.length; i++) {
171       var way = ways[i], nds = way.getElementsByTagName("nd");
172
173       var way_object = {
174         id: way.getAttribute("id"),
175         type: "way",
176         nodes: new Array(nds.length),
177         tags: this.getTags(way)
178       };
179
180       for (var j = 0; j < nds.length; j++) {
181         way_object.nodes[j] = nodes[nds[j].getAttribute("ref")];
182       }
183
184       result.push(way_object);
185     }
186
187     return result;
188   },
189
190   getTags: function (xml) {
191     var result = {};
192
193     var tags = xml.getElementsByTagName("tag");
194     for (var j = 0; j < tags.length; j++) {
195       result[tags[j].getAttribute("k")] = tags[j].getAttribute("v");
196     }
197
198     return result;
199   }
200 });