extended mapview to give information about the current visible tile
layer, continued work on printing
This commit is contained in:
parent
dffd67ef72
commit
7421117278
@ -22,22 +22,6 @@ or see http://www.gnu.org/licenses/agpl.txt.
|
|||||||
OSRM.GLOBALS.map = null;
|
OSRM.GLOBALS.map = null;
|
||||||
|
|
||||||
|
|
||||||
L.MyLayers = L.Control.Layers.extend({
|
|
||||||
getActive: function () {
|
|
||||||
var i, input, obj,
|
|
||||||
inputs = this._form.getElementsByTagName('input'),
|
|
||||||
inputsLen = inputs.length;
|
|
||||||
|
|
||||||
for (i = 0; i < inputsLen; i++) {
|
|
||||||
input = inputs[i];
|
|
||||||
obj = this._layers[input.layerId];
|
|
||||||
if (input.checked && !obj.overlay) {
|
|
||||||
return obj.name;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// map controller
|
// map controller
|
||||||
// [map initialization, event handling]
|
// [map initialization, event handling]
|
||||||
OSRM.Map = {
|
OSRM.Map = {
|
||||||
@ -66,9 +50,8 @@ init: function() {
|
|||||||
});
|
});
|
||||||
|
|
||||||
// add layer control
|
// add layer control
|
||||||
var layersControl = new L.MyLayers(base_maps, {});
|
var layerControl = new L.Control.QueryableLayers(base_maps, {});
|
||||||
OSRM.G.map.layerControl = layersControl;
|
OSRM.G.map.addLayerControl(layerControl);
|
||||||
OSRM.G.map.addControl(layersControl);
|
|
||||||
|
|
||||||
// move zoom markers
|
// move zoom markers
|
||||||
OSRM.Browser.getElementsByClassName(document,'leaflet-control-zoom')[0].style.left=(OSRM.GUI.width+10)+"px";
|
OSRM.Browser.getElementsByClassName(document,'leaflet-control-zoom')[0].style.left=(OSRM.GUI.width+10)+"px";
|
||||||
|
34
WebContent/base/leaflet/L.Control.QueryableLayers.js
Normal file
34
WebContent/base/leaflet/L.Control.QueryableLayers.js
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
/*
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU AFFERO General Public License as published by
|
||||||
|
the Free Software Foundation; either version 3 of the License, or
|
||||||
|
any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Affero General Public License
|
||||||
|
along with this program; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
or see http://www.gnu.org/licenses/agpl.txt.
|
||||||
|
*/
|
||||||
|
|
||||||
|
// queryable Layers control
|
||||||
|
// [simply Control.Layers extended by query functions]
|
||||||
|
L.Control.QueryableLayers = L.Control.Layers.extend({
|
||||||
|
getActiveLayerName: function () {
|
||||||
|
var i, input, obj,
|
||||||
|
inputs = this._form.getElementsByTagName('input'),
|
||||||
|
inputsLen = inputs.length;
|
||||||
|
|
||||||
|
for (i = 0; i < inputsLen; i++) {
|
||||||
|
input = inputs[i];
|
||||||
|
obj = this._layers[input.layerId];
|
||||||
|
if (input.checked && !obj.overlay) {
|
||||||
|
return obj.name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
@ -16,7 +16,7 @@ or see http://www.gnu.org/licenses/agpl.txt.
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// map view/model
|
// map view/model
|
||||||
// [extending Leaflet L.Map with setView/fitBounds methods that respect UI visibility]
|
// [extending Leaflet L.Map with setView/fitBounds methods that respect UI visibility, better layerControl]
|
||||||
OSRM.MapView = L.Map.extend({
|
OSRM.MapView = L.Map.extend({
|
||||||
setViewUI: function(position, zoom, no_animation) {
|
setViewUI: function(position, zoom, no_animation) {
|
||||||
if( OSRM.GUI.visible == true ) {
|
if( OSRM.GUI.visible == true ) {
|
||||||
@ -50,5 +50,25 @@ OSRM.MapView = L.Map.extend({
|
|||||||
var centerPoint = this._getTopLeftPoint().add(viewHalf.divideBy(2));
|
var centerPoint = this._getTopLeftPoint().add(viewHalf.divideBy(2));
|
||||||
|
|
||||||
return this.unproject(centerPoint, this._zoom, unbounded);
|
return this.unproject(centerPoint, this._zoom, unbounded);
|
||||||
|
},
|
||||||
|
addLayerControl: function( layerControl ) {
|
||||||
|
if( this.layerControl )
|
||||||
|
return;
|
||||||
|
|
||||||
|
this.layerControl = layerControl;
|
||||||
|
this.addControl(this.layerControl);
|
||||||
|
},
|
||||||
|
getActiveLayerId: function() {
|
||||||
|
var tile_server_id = 0;
|
||||||
|
|
||||||
|
var tile_servers = OSRM.DEFAULTS.TILE_SERVERS;
|
||||||
|
var tile_server_name = this.layerControl.getActiveLayerName();
|
||||||
|
for(var i=0, size=tile_servers.length; i<size; i++)
|
||||||
|
if( tile_servers[tile_server_id].display_name == tile_server_name ) {
|
||||||
|
tile_server_id = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return tile_server_id;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -37,6 +37,7 @@ or see http://www.gnu.org/licenses/agpl.txt.
|
|||||||
<!-- scripts -->
|
<!-- scripts -->
|
||||||
<script src="leaflet/leaflet-src.js" type="text/javascript"></script>
|
<script src="leaflet/leaflet-src.js" type="text/javascript"></script>
|
||||||
<script src="base/leaflet/L.Bugfixes.js" type="text/javascript"></script>
|
<script src="base/leaflet/L.Bugfixes.js" type="text/javascript"></script>
|
||||||
|
<script src="base/leaflet/L.Control.QueryableLayers.js" type="text/javascript"></script>
|
||||||
<script src="base/leaflet/L.DashedPolyline.js" type="text/javascript"></script>
|
<script src="base/leaflet/L.DashedPolyline.js" type="text/javascript"></script>
|
||||||
<script src="base/leaflet/L.MouseMarker.js" type="text/javascript"></script>
|
<script src="base/leaflet/L.MouseMarker.js" type="text/javascript"></script>
|
||||||
<script src="base/leaflet/L.SwitchableIcon.js" type="text/javascript"></script>
|
<script src="base/leaflet/L.SwitchableIcon.js" type="text/javascript"></script>
|
||||||
|
@ -41,7 +41,9 @@ init: function() {
|
|||||||
// create UI in printwindow
|
// create UI in printwindow
|
||||||
show: function(response) {
|
show: function(response) {
|
||||||
// create header
|
// create header
|
||||||
header =
|
var header =
|
||||||
|
'<thead class="header-group"><tr><td colspan="3">' +
|
||||||
|
|
||||||
'<div class="full">' +
|
'<div class="full">' +
|
||||||
'<div style="display:table-row">' +
|
'<div style="display:table-row">' +
|
||||||
|
|
||||||
@ -67,14 +69,12 @@ show: function(response) {
|
|||||||
|
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'<div class="quad"></div>';
|
|
||||||
|
'<div class="quad"></div>' +
|
||||||
|
'</td></tr></thead>';
|
||||||
|
|
||||||
// create route description
|
// create route description
|
||||||
var route_desc = '';
|
var route_desc = '<tbody class="row-group">';
|
||||||
route_desc += '<table id="thetable" class="results-table medium-font">';
|
|
||||||
route_desc += '<thead style="display:table-header-group;"><tr><td colspan="3">'+header+'</td></tr></thead>';
|
|
||||||
route_desc += '<tbody stlye="display:table-row-group">';
|
|
||||||
|
|
||||||
for(var i=0; i < response.route_instructions.length; i++){
|
for(var i=0; i < response.route_instructions.length; i++){
|
||||||
//odd or even ?
|
//odd or even ?
|
||||||
var rowstyle='results-odd';
|
var rowstyle='results-odd';
|
||||||
@ -106,32 +106,21 @@ show: function(response) {
|
|||||||
route_desc += "</tr>";
|
route_desc += "</tr>";
|
||||||
}
|
}
|
||||||
route_desc += '</tbody>';
|
route_desc += '</tbody>';
|
||||||
route_desc += '</table>';
|
|
||||||
|
|
||||||
// put everything in DOM
|
// put everything in DOM
|
||||||
OSRM.G.printwindow.document.getElementById('description').innerHTML = route_desc;
|
OSRM.G.printwindow.document.getElementById('description').innerHTML = '<table class="results-table medium-font">' + header + route_desc + '</table>';
|
||||||
OSRM.G.printwindow.document.getElementById('overview-map-description').innerHTML =
|
OSRM.G.printwindow.document.getElementById('overview-map-description').innerHTML = '<table class="results-table medium-font">' + header + '</table>';
|
||||||
'<table id="" class="results-table medium-font">' +
|
|
||||||
'<thead style="display:table-header-group;"><tr><td colspan="3">'+header+'</td></tr></thead>'+
|
|
||||||
'</table>';
|
|
||||||
|
|
||||||
// init map
|
// draw map
|
||||||
var tile_servers = OSRM.DEFAULTS.TILE_SERVERS;
|
var tile_server_id = OSRM.MapView.getActiveLayerId();
|
||||||
var tile_server_name = OSRM.G.map.layerControl.getActive();
|
var map = OSRM.G.printwindow.initialize( OSRM.DEFAULTS.TILE_SERVERS[tile_server_id] );
|
||||||
var tile_server_id = 0;
|
// draw markers
|
||||||
for(var size=tile_servers.length;tile_server_id < size; tile_server_id++) {
|
|
||||||
if( tile_servers[tile_server_id].display_name == tile_server_name )
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
OSRM.Printing.map = OSRM.G.printwindow.initialize( OSRM.DEFAULTS.TILE_SERVERS[tile_server_id] );
|
|
||||||
var map = OSRM.Printing.map;
|
|
||||||
var markers = OSRM.G.markers.route;
|
var markers = OSRM.G.markers.route;
|
||||||
map.addLayer( new L.MouseMarker( markers[0].getPosition(), {draggable:false,clickable:false,icon:OSRM.G.icons['marker-source']} ) );
|
map.addLayer( new L.MouseMarker( markers[0].getPosition(), {draggable:false,clickable:false,icon:OSRM.G.icons['marker-source']} ) );
|
||||||
for(var i=1, size=markers.length-1; i<size; i++)
|
for(var i=1, size=markers.length-1; i<size; i++)
|
||||||
map.addLayer( new L.MouseMarker( markers[i].getPosition(), {draggable:false,clickable:false,icon:OSRM.G.icons['marker-via']} ) );
|
map.addLayer( new L.MouseMarker( markers[i].getPosition(), {draggable:false,clickable:false,icon:OSRM.G.icons['marker-via']} ) );
|
||||||
map.addLayer( new L.MouseMarker( markers[markers.length-1].getPosition(), {draggable:false,clickable:false,icon:OSRM.G.icons['marker-target']} ));
|
map.addLayer( new L.MouseMarker( markers[markers.length-1].getPosition(), {draggable:false,clickable:false,icon:OSRM.G.icons['marker-target']} ));
|
||||||
|
// draw route
|
||||||
OSRM.Printing.route = new L.DashedPolyline();
|
OSRM.Printing.route = new L.DashedPolyline();
|
||||||
var route = OSRM.Printing.route;
|
var route = OSRM.Printing.route;
|
||||||
route.setLatLngs( OSRM.G.route.getPositions() );
|
route.setLatLngs( OSRM.G.route.getPositions() );
|
||||||
@ -139,8 +128,7 @@ show: function(response) {
|
|||||||
map.addLayer( route );
|
map.addLayer( route );
|
||||||
var bounds = new L.LatLngBounds( OSRM.G.route.getPositions() );
|
var bounds = new L.LatLngBounds( OSRM.G.route.getPositions() );
|
||||||
map.fitBoundsUI( bounds );
|
map.fitBoundsUI( bounds );
|
||||||
|
// query for a better route geometry
|
||||||
// query better geometry
|
|
||||||
var zoom = map.getBoundsZoom(bounds);
|
var zoom = map.getBoundsZoom(bounds);
|
||||||
OSRM.JSONP.call(OSRM.Routing._buildCall()+'&z='+zoom+'&instructions=false', OSRM.Printing.drawRoute, OSRM.Printing.timeoutRoute, OSRM.DEFAULTS.JSONP_TIMEOUT, 'print');
|
OSRM.JSONP.call(OSRM.Routing._buildCall()+'&z='+zoom+'&instructions=false', OSRM.Printing.drawRoute, OSRM.Printing.timeoutRoute, OSRM.DEFAULTS.JSONP_TIMEOUT, 'print');
|
||||||
},
|
},
|
||||||
|
@ -256,3 +256,11 @@ div.header-title
|
|||||||
text-align:center;
|
text-align:center;
|
||||||
vertical-align:middle;
|
vertical-align:middle;
|
||||||
}
|
}
|
||||||
|
.header-group
|
||||||
|
{
|
||||||
|
display:table-header-group;
|
||||||
|
}
|
||||||
|
.row-group
|
||||||
|
{
|
||||||
|
display:table-row-group;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user