| 1 | /**
|
|---|
| 2 | * Var 'map' is set global, used in 'heatmap_extensions.js'.
|
|---|
| 3 | */
|
|---|
| 4 | var map;
|
|---|
| 5 |
|
|---|
| 6 | function init_heatmap(){
|
|---|
| 7 | var lat = getURLParameter('lat');
|
|---|
| 8 | var lon = getURLParameter('lon');
|
|---|
| 9 | var zoom = getURLParameter('zoom');
|
|---|
| 10 |
|
|---|
| 11 | if(lat=='null' || lon=='null' || zoom=='null'){
|
|---|
| 12 | var lat = 52.15514;
|
|---|
| 13 | var lon = 4.48959;
|
|---|
| 14 | var zoom = 13;
|
|---|
| 15 | }
|
|---|
| 16 | var projection_wgs = new OpenLayers.Projection("EPSG:4326"); // WGS 1984
|
|---|
| 17 |
|
|---|
| 18 | map = new OpenLayers.Map('heatmap', {
|
|---|
| 19 | theme: null,
|
|---|
| 20 | controls: [
|
|---|
| 21 | new OpenLayers.Control.Navigation(),
|
|---|
| 22 | new OpenLayers.Control.Permalink({
|
|---|
| 23 | anchor : false,
|
|---|
| 24 | createParams: function(center, zoom, layers) {
|
|---|
| 25 | center = center || this.map.getCenter();
|
|---|
| 26 |
|
|---|
| 27 | var params = OpenLayers.Util.getParameters(this.base);
|
|---|
| 28 |
|
|---|
| 29 | // If there's still no center, map is not initialized yet.
|
|---|
| 30 | // Break out of this function, and simply return the params from the
|
|---|
| 31 | // base link.
|
|---|
| 32 | if (center) {
|
|---|
| 33 |
|
|---|
| 34 | //zoom
|
|---|
| 35 | params.zoom = zoom || this.map.getZoom();
|
|---|
| 36 |
|
|---|
| 37 | //lon,lat
|
|---|
| 38 | var lat = center.lat;
|
|---|
| 39 | var lon = center.lon;
|
|---|
| 40 |
|
|---|
| 41 | if (this.displayProjection) {
|
|---|
| 42 | var mapPosition = OpenLayers.Projection.transform(
|
|---|
| 43 | { x: lon, y: lat },
|
|---|
| 44 | this.map.getProjectionObject(),
|
|---|
| 45 | this.displayProjection );
|
|---|
| 46 | lon = mapPosition.x;
|
|---|
| 47 | lat = mapPosition.y;
|
|---|
| 48 | }
|
|---|
| 49 | params.lat = Math.round(lat*100000)/100000;
|
|---|
| 50 | params.lon = Math.round(lon*100000)/100000;
|
|---|
| 51 |
|
|---|
| 52 | //layers
|
|---|
| 53 | layers = layers || this.map.layers;
|
|---|
| 54 | params.layers = '';
|
|---|
| 55 | for (var i=0, len=layers.length; i<len; i++) {
|
|---|
| 56 | var layer = layers[i];
|
|---|
| 57 |
|
|---|
| 58 | if (layer.isBaseLayer) {
|
|---|
| 59 | params.layers += (layer == this.map.baseLayer) ? "B" : "0";
|
|---|
| 60 | } else {
|
|---|
| 61 | params.layers += (layer.getVisibility()) ? "T" : "F";
|
|---|
| 62 | }
|
|---|
| 63 | }
|
|---|
| 64 | // Update permalink URL to reflect new location and filters
|
|---|
| 65 | layerid = 0;
|
|---|
| 66 | // First two and last one should be ignored
|
|---|
| 67 | for (var i=4, len=layers.length; i < len; i++) {
|
|---|
| 68 | var layer = layers[i];
|
|---|
| 69 | if ($.isArray(layer.url)) {
|
|---|
| 70 | var url = layer.url[0];
|
|---|
| 71 | } else {
|
|---|
| 72 | var url = layer.url;
|
|---|
| 73 | }
|
|---|
| 74 | var filter = url.split('?')[1];
|
|---|
| 75 | layerid += 1;
|
|---|
| 76 | params['layername' + layerid] = layer.name;
|
|---|
| 77 | params['layercolour' + layerid] = layer.colour;
|
|---|
| 78 | params['layerfilter' + layerid] = filter;
|
|---|
| 79 | }
|
|---|
| 80 | params['layercount'] = layerid;
|
|---|
| 81 | }
|
|---|
| 82 | return params;
|
|---|
| 83 | },
|
|---|
| 84 | draw: function() {
|
|---|
| 85 | OpenLayers.Control.prototype.draw.apply(this, arguments);
|
|---|
| 86 |
|
|---|
| 87 | if (!this.element && !this.anchor) {
|
|---|
| 88 | this.element = document.createElement("a");
|
|---|
| 89 | this.element.innerHTML = OpenLayers.i18n("Permalink");
|
|---|
| 90 | this.element.href="";
|
|---|
| 91 | this.div.appendChild(this.element);
|
|---|
| 92 | }
|
|---|
| 93 | this.map.events.on({
|
|---|
| 94 | 'moveend': this.updateLink,
|
|---|
| 95 | 'changelayer': this.updateLink,
|
|---|
| 96 | 'addlayer': this.updateLink,
|
|---|
| 97 | 'removelayer': this.updateLink,
|
|---|
| 98 | 'changebaselayer': this.updateLink,
|
|---|
| 99 | scope: this
|
|---|
| 100 | });
|
|---|
| 101 |
|
|---|
| 102 | // Make it so there is at least a link even though the map may not have
|
|---|
| 103 | // moved yet.
|
|---|
| 104 | this.updateLink();
|
|---|
| 105 |
|
|---|
| 106 | return this.div;
|
|---|
| 107 | },
|
|---|
| 108 | }),
|
|---|
| 109 | new OpenLayers.Control.PanZoomBar(),
|
|---|
| 110 | new OpenLayers.Control.ZoomBox(),
|
|---|
| 111 | new OpenLayers.Control.OverviewMap({
|
|---|
| 112 | maximized : false,
|
|---|
| 113 | mapOptions: { theme: null }
|
|---|
| 114 | }),
|
|---|
| 115 | new OpenLayers.Control.MousePosition({ 'displayProjection' : projection_wgs })
|
|---|
| 116 | /**
|
|---|
| 117 | * Decided to disable these controls.
|
|---|
| 118 | * The layerswitcher has been replaced with a custom one. If you want the original back,
|
|---|
| 119 | * make sure to disable the custom one to prevent collision.
|
|---|
| 120 | */
|
|---|
| 121 |
|
|---|
| 122 | //new OpenLayers.Control.PanZoomBav(),
|
|---|
| 123 | //new OpenLayers.Control.ScaleLine(),
|
|---|
| 124 | //new OpenLayers.Control.LayerSwitcher(),
|
|---|
| 125 | ],
|
|---|
| 126 | maxExtent: new OpenLayers.Bounds(-20037508.3427892,-20037508.3427892,20037508.3427892,20037508.3427892),
|
|---|
| 127 | numZoomLevels:16,
|
|---|
| 128 | maxResolution:156543.0339,
|
|---|
| 129 | units:'m',
|
|---|
| 130 | projection: "EPSG:900913",
|
|---|
| 131 | displayProjection: new OpenLayers.Projection("EPSG:4326")
|
|---|
| 132 | });
|
|---|
| 133 |
|
|---|
| 134 | map.events.register('click', map, GetMousePos);
|
|---|
| 135 | function GetMousePos(pos) {
|
|---|
| 136 | var pix = map.getLonLatFromPixel(new OpenLayers.Pixel(pos.xy.x,pos.xy.y));
|
|---|
| 137 | var mousepos = OpenLayers.Layer.SphericalMercator.inverseMercator(pix.lon, pix.lat);
|
|---|
| 138 | var zoomlevel = map.getZoom();
|
|---|
| 139 | getNodeList(zoom, mousepos);
|
|---|
| 140 | }
|
|---|
| 141 |
|
|---|
| 142 | layerMapnik = new OpenLayers.Layer.OSM.Mapnik("Mapnik");
|
|---|
| 143 | map.addLayer(layerMapnik);
|
|---|
| 144 |
|
|---|
| 145 | var lonLat = new OpenLayers.LonLat(lon, lat).transform(new OpenLayers.Projection("EPSG:4326"), map.getProjectionObject());
|
|---|
| 146 | map.setCenter (lonLat, zoom);
|
|---|
| 147 |
|
|---|
| 148 |
|
|---|
| 149 | /**
|
|---|
| 150 | * Layers are created and put in switcher
|
|---|
| 151 | */
|
|---|
| 152 | function add_item(category, layer) {
|
|---|
| 153 | map.addLayer(layer);
|
|---|
| 154 | var checked = '';
|
|---|
| 155 | if (layer.getVisibility()) { checked = "checked='checked'"; };
|
|---|
| 156 | $("#" + category).append("<span id=\"" + layer.name + "\">" +
|
|---|
| 157 | " <div id='layer_switcher_colour' style='background-color:rgb(" + layer.colour + ")' />" +
|
|---|
| 158 | "<input type='checkbox' id='togglelayer' " + checked + " /><font>" + layer.name + " </font><br /></span>"
|
|---|
| 159 | );
|
|---|
| 160 | }
|
|---|
| 161 |
|
|---|
| 162 | var signallayer = new OpenLayers.Layer.OSM.Overlay4("signallayer", {isBaseLayer: false, visibility: false});
|
|---|
| 163 | var wlsignalLayer = new OpenLayers.Layer.OSM.Overlay3("Wireless Leiden Coverage", {isBaseLayer: false, visibility: true});
|
|---|
| 164 | var nodesLayer = new OpenLayers.Layer.GML.NodesOverlay("Node Locations", {isBaseLayer: false, visibility: false});
|
|---|
| 165 |
|
|---|
| 166 | add_item('default', signallayer);
|
|---|
| 167 | add_item('default', wlsignalLayer);
|
|---|
| 168 | add_item('features', nodesLayer);
|
|---|
| 169 | }
|
|---|