mirror of
https://github.com/osm-search/Nominatim.git
synced 2024-12-27 06:51:42 +03:00
Allow map to wrap-around, still longitude should be -180..+180
This commit is contained in:
parent
000fe3ddff
commit
0896c07972
@ -32,7 +32,6 @@ jQuery(document).ready(function(){
|
|||||||
});
|
});
|
||||||
|
|
||||||
L.tileLayer(nominatim_map_init.tile_url, {
|
L.tileLayer(nominatim_map_init.tile_url, {
|
||||||
noWrap: true, // otherwise we end up with click coordinates like latitude -728
|
|
||||||
// moved to footer
|
// moved to footer
|
||||||
attribution: (nominatim_map_init.tile_attribution || null ) //'© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
|
attribution: (nominatim_map_init.tile_attribution || null ) //'© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
|
||||||
}).addTo(map);
|
}).addTo(map);
|
||||||
@ -78,6 +77,9 @@ jQuery(document).ready(function(){
|
|||||||
|
|
||||||
function display_map_position(mouse_lat_lng){
|
function display_map_position(mouse_lat_lng){
|
||||||
|
|
||||||
|
if (mouse_lat_lng) {
|
||||||
|
mouse_lat_lng = map.wrapLatLng(mouse_lat_lng);
|
||||||
|
}
|
||||||
html_mouse = "mouse position " + (mouse_lat_lng ? [mouse_lat_lng.lat.toFixed(5), mouse_lat_lng.lng.toFixed(5)].join(',') : '-');
|
html_mouse = "mouse position " + (mouse_lat_lng ? [mouse_lat_lng.lat.toFixed(5), mouse_lat_lng.lng.toFixed(5)].join(',') : '-');
|
||||||
html_click = "last click: " + (last_click_latlng ? [last_click_latlng.lat.toFixed(5),last_click_latlng.lng.toFixed(5)].join(',') : '-');
|
html_click = "last click: " + (last_click_latlng ? [last_click_latlng.lat.toFixed(5),last_click_latlng.lng.toFixed(5)].join(',') : '-');
|
||||||
|
|
||||||
@ -92,9 +94,10 @@ jQuery(document).ready(function(){
|
|||||||
|
|
||||||
$('#map-position-inner').html([html_center,html_zoom,html_viewbox,html_click,html_mouse].join('<br/>'));
|
$('#map-position-inner').html([html_center,html_zoom,html_viewbox,html_click,html_mouse].join('<br/>'));
|
||||||
|
|
||||||
|
var center_lat_lng = map.wrapLatLng(map.getCenter());
|
||||||
var reverse_params = {
|
var reverse_params = {
|
||||||
lat: map.getCenter().lat.toFixed(5),
|
lat: center_lat_lng.lat.toFixed(5),
|
||||||
lon: map.getCenter().lng.toFixed(5),
|
lon: center_lat_lng.lng.toFixed(5),
|
||||||
zoom: map.getZoom(),
|
zoom: map.getZoom(),
|
||||||
format: 'html'
|
format: 'html'
|
||||||
}
|
}
|
||||||
@ -134,12 +137,22 @@ jQuery(document).ready(function(){
|
|||||||
|
|
||||||
|
|
||||||
function map_viewbox_as_string() {
|
function map_viewbox_as_string() {
|
||||||
// since .toBBoxString() doesn't round numbers
|
var bounds = map.getBounds();
|
||||||
|
var west = bounds.getWest();
|
||||||
|
var east = bounds.getEast();
|
||||||
|
|
||||||
|
if ((east - west) >= 360) { // covers more than whole planet
|
||||||
|
west = map.getCenter().lng-179.999;
|
||||||
|
east = map.getCenter().lng+179.999;
|
||||||
|
}
|
||||||
|
east = L.latLng(77, east).wrap().lng;
|
||||||
|
west = L.latLng(77, west).wrap().lng;
|
||||||
|
|
||||||
return [
|
return [
|
||||||
map.getBounds().getSouthWest().lng.toFixed(5), // left
|
west.toFixed(5), // left
|
||||||
map.getBounds().getNorthEast().lat.toFixed(5), // top
|
bounds.getNorth().toFixed(5), // top
|
||||||
map.getBounds().getNorthEast().lng.toFixed(5), // right
|
east.toFixed(5), // right
|
||||||
map.getBounds().getSouthWest().lat.toFixed(5) // bottom
|
bounds.getSouth().toFixed(5) // bottom
|
||||||
].join(',');
|
].join(',');
|
||||||
}
|
}
|
||||||
function map_link_to_osm(){
|
function map_link_to_osm(){
|
||||||
@ -236,7 +249,7 @@ jQuery(document).ready(function(){
|
|||||||
if ( is_reverse_search ){
|
if ( is_reverse_search ){
|
||||||
map.on('click', function(e){
|
map.on('click', function(e){
|
||||||
$('form input[name=lat]').val( e.latlng.lat);
|
$('form input[name=lat]').val( e.latlng.lat);
|
||||||
$('form input[name=lon]').val( e.latlng.lng);
|
$('form input[name=lon]').val( e.latlng.wrap().lng);
|
||||||
$('form').submit();
|
$('form').submit();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user