路线规划需要双击
Route planning needs double click
我尝试做一个小型的路线规划应用。应输入起始地址并且目的地是固定的。从给定的起点计算最短路线并显示结果。此外,我展示了一个带有 Openlayers 的示例 osm 地图,但我使用 Google Maps API v3 计算它并在 1px x 1px 的默认地图中显示它。到目前为止,我的实施工作正常,但出现了一个问题:
如果您点击一次 "Search" 什么也不会发生。如果你点击两次,它就会做我想要的。任何解决方案?所以这是主文件的代码:
<?php
//some php code.....
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Home</title>
<meta name="keywords" content="Kletterhallen, Boulderhallen">
<link rel="stylesheet" href="../styles/basic/stylesheet.css" />
<link rel="shortcut icon" href="../styles/basic/favicon.ico" />
<script type="text/JavaScript" src="../js/sha512.js"></script>
<script type="text/JavaScript" src="../js/form.js"></script>
<script src="https://maps.googleapis.com/maps/api/js?v=3.exp&signed_in=true"></script>
<script>
/****************************************************
*
* DEFINE DIRECTIONS
*
*****************************************************/
var directionsDisplay;
var directionsService = new google.maps.DirectionsService();
var map;
var place=[];
var dist=[];
var gooco=[];
var neuwaldegg = new google.maps.LatLng(48.237509, 16.285983);
var khWien = new google.maps.LatLng(48.229765, 16.451519);
var oegvKz = new google.maps.LatLng(48.206431, 16.350771);
var ktz = new google.maps.LatLng(48.208769, 16.376707);
var bcedelw = new google.maps.LatLng(48.202942, 16.372778);
var kzsaus = new google.maps.LatLng(48.210542, 16.374989);
var szmarswiese = new google.maps.LatLng(48.239806, 16.276138);
var kzkloster = new google.maps.LatLng(48.310744, 16.327837);
var nwkl = new google.maps.LatLng(48.380266, 16.509789);
var ribpark = new google.maps.LatLng(47.930880, 16.200566);
var boulderbar = new google.maps.LatLng(48.231408, 16.368489);
var dest=[neuwaldegg,khWien,oegvKz,ktz,bcedelw,kzsaus,szmarswiese,kzkloster,nwkl,ribpark,boulderbar];
/****************************************************
*
* INITIALIZE MAP
*
*****************************************************/
function initialize() {
directionsDisplay = new google.maps.DirectionsRenderer();
var vienna = new google.maps.LatLng(48.231408, 16.368489);
var mapOptions = {
zoom: 6,
center: vienna
}
map = new google.maps.Map(document.getElementById('routecalc'), mapOptions);
directionsDisplay.setMap(map);
}
/****************************************************
*
* GET POLYLINE OF SHORTEST ROUTES
*
*****************************************************/
function calcRoute(start) {
var start=start.value;
for (var k = 0; k < dest.length; k++) {
var end = dest[k];
var request = {
origin: start,
destination: end,
optimizeWaypoints: true,
travelMode: google.maps.TravelMode.WALKING
};
directionsService.route(request, function(response, status) {
if (status == google.maps.DirectionsStatus.OK) {
directionsDisplay.setDirections(response);
var route = response.routes[0];
for (var i = 0; i < route.legs.length; i++) {
startaddress=route.legs[i].start_address;
place.push(route.legs[i].end_address)
var zws=route.legs[i].distance.text;
zws=zws.split(" ");
zws=parseFloat(zws[0]);
dist.push(zws);
gooco.push(route.overview_polyline);
}
}
});
}
var index=[];
var min=[];
for (var j = 0; j < dist.length; j++) {
if(j==0){
min.push(dist[0]);
index.push(0);
}
else if(dist[j]<min[0]){
min=[];
index=[];
min.push(dist[j]);
index.push(j);
}
else if(dist[j]==min[0]){
min.push(dist[j]);
index.push(j);
}
else{
continue;
}
}
var summaryPanel = document.getElementById('directions_panel');
summaryPanel.innerHTML = '';
summaryPanel.innerHTML += '<b>Your search results:</b><br>';
for (var t = 0; t < index.length; t++) {
summaryPanel.innerHTML += 'Your entered adress: '+startaddress+ '<br>';
summaryPanel.innerHTML += 'Your entered destination: '+place[index[t]]+ '<br>';
summaryPanel.innerHTML += 'Distance: '+dist[index[t]]+' km'+ '<br><br>';
}
}
google.maps.event.addDomListener(window, 'load', initialize);
</script>
</head>
<body>
<div id="routecalc">
</div>
<!-- HEADER -->
<div id="Header">
<img id="Logo" src="../styles/basic/Logo.gif" alt="Logo">
<img id="Headline" src="../styles/basic/Headline.gif" alt="Headline">
<a href="normalview.php"><img id="German" src="../styles/basic/german.png"></a>
<a href="normalview.php"><img id="English" src="../styles/basic/english.gif"></a>
</div>
<!-- MAP-->
<iframe id="Map" src="map/map.html">
<a href="map/map.html">OSM Maps</a>
</iframe>
<!-- SEARCH -->
<form id="Search" action="" method="post" name="form">
<p>Nächstgelegene Halle von
<input name="start" type="text" size="20" maxlength="30"/>
<input type="button"
value="Search"
onclick="calcRoute(this.form.start);" />
</p>
</form>
<!--SEARCH RESULTS-->
<div id="directions_panel"></div>
<!-- FOOTER -->
</body>
</html>
我认为这与问题无关,但这里也是map.html的代码:
<html><body>
<div id="mapdiv"></div>
<script src="http://www.openlayers.org/api/OpenLayers.js"></script>
<script>
map = new OpenLayers.Map("mapdiv");
map.addLayer(new OpenLayers.Layer.OSM());
var lonLat = new OpenLayers.LonLat(16.367639,48.1986347)
.transform(
new OpenLayers.Projection("EPSG:4326"),
map.getProjectionObject()
);
var zoom=12;
map.setCenter (lonLat, zoom);
</script>
</body></html>
如果您需要任何进一步的信息,请告诉我。非常感谢。
欢迎克拉克斯
我自己解决了这个问题,希望我能帮助别人解决我的问题。我使用了 Google Maps API DirectionMatrix,它比 DirectionService 更适合。这是代码:
<?php
//some php code.....
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Home</title>
<meta name="keywords" content="Kletterhallen, Boulderhallen">
<link rel="stylesheet" href="../styles/basic/stylesheet.css" />
<link rel="shortcut icon" href="../styles/basic/favicon.ico" />
<script type="text/JavaScript" src="../js/sha512.js"></script>
<script type="text/JavaScript" src="../js/form.js"></script>
<script src="http://maps.googleapis.com/maps/api/js?v=3.exp&signed_in=true"></script>
<script>
/****************************************************
*
* DEFINE DIRECTIONS
*
*****************************************************/
function initialize() {
var vienna = new google.maps.LatLng(48.231408, 16.368489);
var mapOptions = {
zoom: 6,
center: vienna
}
map = new google.maps.Map(document.getElementById('routecalc'), mapOptions);
geocoder = new google.maps.Geocoder();
}
function calculateDistances(originstr) {
var map;
var geocoder;
var start=[];
var gooco=[];
var neuwaldegg = new google.maps.LatLng(48.237509, 16.285983);
var khWien = new google.maps.LatLng(48.229765, 16.451519);
var oegvKz = new google.maps.LatLng(48.206431, 16.350771);
var ktz = new google.maps.LatLng(48.208769, 16.376707);
var bcedelw = new google.maps.LatLng(48.202942, 16.372778);
var kzsaus = new google.maps.LatLng(48.210542, 16.374989);
var szmarswiese = new google.maps.LatLng(48.239806, 16.276138);
var kzkloster = new google.maps.LatLng(48.310744, 16.327837);
var nwkl = new google.maps.LatLng(48.380266, 16.509789);
var ribpark = new google.maps.LatLng(47.930880, 16.200566);
var boulderbar = new google.maps.LatLng(48.231408, 16.368489);
var dest=[neuwaldegg,khWien,oegvKz,ktz,bcedelw,kzsaus,szmarswiese,kzkloster,nwkl,ribpark,boulderbar];
start.push(originstr.value);
var service = new google.maps.DistanceMatrixService();
service.getDistanceMatrix(
{
origins: start,
destinations: dest,
travelMode: google.maps.TravelMode.WALKING,
unitSystem: google.maps.UnitSystem.METRIC,
avoidHighways: false,
avoidTolls: false
}, callback);
}
function callback(response, status) {
var dist=[];
if (status != google.maps.DistanceMatrixStatus.OK) {
alert('Error was: ' + status);
} else {
var origins = response.originAddresses;
var destinations = response.destinationAddresses;
var outputDiv = document.getElementById('directions_panel');
outputDiv.innerHTML = '';
var results = response.rows[0].elements;
for (var k = 0; k < results.length; k++) {
var zws=results[k].distance.text;
zws=zws.split(" ");
zws=parseFloat(zws[0]);
dist.push(zws);
}
var index=[];
var min=[];
for (var j = 0; j < dist.length; j++) {
if(j==0){
min.push(dist[0]);
index.push(0);
}
else if(dist[j]<min[0]){
min=[];
index=[];
min.push(dist[j]);
index.push(j);
}
else if(dist[j]==min[0]){
min.push(dist[j]);
index.push(j);
}
else{
continue;
}
}
for (var l = 0; l < index.length; l++) {
outputDiv.innerHTML += 'Your entered adress: '+origins[0]+ '<br>';
outputDiv.innerHTML += 'Your destination: '+destinations[index[l]]+ '<br>';
outputDiv.innerHTML += 'Distance: '+results[index[l]].distance.text+'<br>';
outputDiv.innerHTML += 'Estimated Time: '+results[index[l]].duration.text+'<br><br>';
}
}
}
google.maps.event.addDomListener(window, 'load', initialize);
</script>
</head>
<body>
<div id="routecalc">
</div>
<!-- HEADER -->
<div id="Header">
<img id="Logo" src="../styles/basic/Logo.gif" alt="Logo">
<img id="Headline" src="../styles/basic/Headline.gif" alt="Headline">
<a href="normalview.php"><img id="German" src="../styles/basic/german.png"></a>
<a href="normalview.php"><img id="English" src="../styles/basic/english.gif"></a>
</div>
<!-- MAP-->
<iframe id="Map" src="map/map.html">
<a href="map/map.html">OSM Maps</a>
</iframe>
<!-- SEARCH -->
<form id="Search" action="" method="post" name="form">
<p>Nächstgelegene Halle von
<input name="start" type="text" size="20" maxlength="30"/>
<input type="button"
value="Search"
onclick="calculateDistances(this.form.start);" />
</p>
</form>
<!--SEARCH RESULTS-->
<!-- FOOTER -->
<div id="directions_panel"></div>
</body>
</html>
欢迎克拉克斯
我尝试做一个小型的路线规划应用。应输入起始地址并且目的地是固定的。从给定的起点计算最短路线并显示结果。此外,我展示了一个带有 Openlayers 的示例 osm 地图,但我使用 Google Maps API v3 计算它并在 1px x 1px 的默认地图中显示它。到目前为止,我的实施工作正常,但出现了一个问题:
如果您点击一次 "Search" 什么也不会发生。如果你点击两次,它就会做我想要的。任何解决方案?所以这是主文件的代码:
<?php
//some php code.....
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Home</title>
<meta name="keywords" content="Kletterhallen, Boulderhallen">
<link rel="stylesheet" href="../styles/basic/stylesheet.css" />
<link rel="shortcut icon" href="../styles/basic/favicon.ico" />
<script type="text/JavaScript" src="../js/sha512.js"></script>
<script type="text/JavaScript" src="../js/form.js"></script>
<script src="https://maps.googleapis.com/maps/api/js?v=3.exp&signed_in=true"></script>
<script>
/****************************************************
*
* DEFINE DIRECTIONS
*
*****************************************************/
var directionsDisplay;
var directionsService = new google.maps.DirectionsService();
var map;
var place=[];
var dist=[];
var gooco=[];
var neuwaldegg = new google.maps.LatLng(48.237509, 16.285983);
var khWien = new google.maps.LatLng(48.229765, 16.451519);
var oegvKz = new google.maps.LatLng(48.206431, 16.350771);
var ktz = new google.maps.LatLng(48.208769, 16.376707);
var bcedelw = new google.maps.LatLng(48.202942, 16.372778);
var kzsaus = new google.maps.LatLng(48.210542, 16.374989);
var szmarswiese = new google.maps.LatLng(48.239806, 16.276138);
var kzkloster = new google.maps.LatLng(48.310744, 16.327837);
var nwkl = new google.maps.LatLng(48.380266, 16.509789);
var ribpark = new google.maps.LatLng(47.930880, 16.200566);
var boulderbar = new google.maps.LatLng(48.231408, 16.368489);
var dest=[neuwaldegg,khWien,oegvKz,ktz,bcedelw,kzsaus,szmarswiese,kzkloster,nwkl,ribpark,boulderbar];
/****************************************************
*
* INITIALIZE MAP
*
*****************************************************/
function initialize() {
directionsDisplay = new google.maps.DirectionsRenderer();
var vienna = new google.maps.LatLng(48.231408, 16.368489);
var mapOptions = {
zoom: 6,
center: vienna
}
map = new google.maps.Map(document.getElementById('routecalc'), mapOptions);
directionsDisplay.setMap(map);
}
/****************************************************
*
* GET POLYLINE OF SHORTEST ROUTES
*
*****************************************************/
function calcRoute(start) {
var start=start.value;
for (var k = 0; k < dest.length; k++) {
var end = dest[k];
var request = {
origin: start,
destination: end,
optimizeWaypoints: true,
travelMode: google.maps.TravelMode.WALKING
};
directionsService.route(request, function(response, status) {
if (status == google.maps.DirectionsStatus.OK) {
directionsDisplay.setDirections(response);
var route = response.routes[0];
for (var i = 0; i < route.legs.length; i++) {
startaddress=route.legs[i].start_address;
place.push(route.legs[i].end_address)
var zws=route.legs[i].distance.text;
zws=zws.split(" ");
zws=parseFloat(zws[0]);
dist.push(zws);
gooco.push(route.overview_polyline);
}
}
});
}
var index=[];
var min=[];
for (var j = 0; j < dist.length; j++) {
if(j==0){
min.push(dist[0]);
index.push(0);
}
else if(dist[j]<min[0]){
min=[];
index=[];
min.push(dist[j]);
index.push(j);
}
else if(dist[j]==min[0]){
min.push(dist[j]);
index.push(j);
}
else{
continue;
}
}
var summaryPanel = document.getElementById('directions_panel');
summaryPanel.innerHTML = '';
summaryPanel.innerHTML += '<b>Your search results:</b><br>';
for (var t = 0; t < index.length; t++) {
summaryPanel.innerHTML += 'Your entered adress: '+startaddress+ '<br>';
summaryPanel.innerHTML += 'Your entered destination: '+place[index[t]]+ '<br>';
summaryPanel.innerHTML += 'Distance: '+dist[index[t]]+' km'+ '<br><br>';
}
}
google.maps.event.addDomListener(window, 'load', initialize);
</script>
</head>
<body>
<div id="routecalc">
</div>
<!-- HEADER -->
<div id="Header">
<img id="Logo" src="../styles/basic/Logo.gif" alt="Logo">
<img id="Headline" src="../styles/basic/Headline.gif" alt="Headline">
<a href="normalview.php"><img id="German" src="../styles/basic/german.png"></a>
<a href="normalview.php"><img id="English" src="../styles/basic/english.gif"></a>
</div>
<!-- MAP-->
<iframe id="Map" src="map/map.html">
<a href="map/map.html">OSM Maps</a>
</iframe>
<!-- SEARCH -->
<form id="Search" action="" method="post" name="form">
<p>Nächstgelegene Halle von
<input name="start" type="text" size="20" maxlength="30"/>
<input type="button"
value="Search"
onclick="calcRoute(this.form.start);" />
</p>
</form>
<!--SEARCH RESULTS-->
<div id="directions_panel"></div>
<!-- FOOTER -->
</body>
</html>
我认为这与问题无关,但这里也是map.html的代码:
<html><body>
<div id="mapdiv"></div>
<script src="http://www.openlayers.org/api/OpenLayers.js"></script>
<script>
map = new OpenLayers.Map("mapdiv");
map.addLayer(new OpenLayers.Layer.OSM());
var lonLat = new OpenLayers.LonLat(16.367639,48.1986347)
.transform(
new OpenLayers.Projection("EPSG:4326"),
map.getProjectionObject()
);
var zoom=12;
map.setCenter (lonLat, zoom);
</script>
</body></html>
如果您需要任何进一步的信息,请告诉我。非常感谢。
欢迎克拉克斯
我自己解决了这个问题,希望我能帮助别人解决我的问题。我使用了 Google Maps API DirectionMatrix,它比 DirectionService 更适合。这是代码:
<?php
//some php code.....
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Home</title>
<meta name="keywords" content="Kletterhallen, Boulderhallen">
<link rel="stylesheet" href="../styles/basic/stylesheet.css" />
<link rel="shortcut icon" href="../styles/basic/favicon.ico" />
<script type="text/JavaScript" src="../js/sha512.js"></script>
<script type="text/JavaScript" src="../js/form.js"></script>
<script src="http://maps.googleapis.com/maps/api/js?v=3.exp&signed_in=true"></script>
<script>
/****************************************************
*
* DEFINE DIRECTIONS
*
*****************************************************/
function initialize() {
var vienna = new google.maps.LatLng(48.231408, 16.368489);
var mapOptions = {
zoom: 6,
center: vienna
}
map = new google.maps.Map(document.getElementById('routecalc'), mapOptions);
geocoder = new google.maps.Geocoder();
}
function calculateDistances(originstr) {
var map;
var geocoder;
var start=[];
var gooco=[];
var neuwaldegg = new google.maps.LatLng(48.237509, 16.285983);
var khWien = new google.maps.LatLng(48.229765, 16.451519);
var oegvKz = new google.maps.LatLng(48.206431, 16.350771);
var ktz = new google.maps.LatLng(48.208769, 16.376707);
var bcedelw = new google.maps.LatLng(48.202942, 16.372778);
var kzsaus = new google.maps.LatLng(48.210542, 16.374989);
var szmarswiese = new google.maps.LatLng(48.239806, 16.276138);
var kzkloster = new google.maps.LatLng(48.310744, 16.327837);
var nwkl = new google.maps.LatLng(48.380266, 16.509789);
var ribpark = new google.maps.LatLng(47.930880, 16.200566);
var boulderbar = new google.maps.LatLng(48.231408, 16.368489);
var dest=[neuwaldegg,khWien,oegvKz,ktz,bcedelw,kzsaus,szmarswiese,kzkloster,nwkl,ribpark,boulderbar];
start.push(originstr.value);
var service = new google.maps.DistanceMatrixService();
service.getDistanceMatrix(
{
origins: start,
destinations: dest,
travelMode: google.maps.TravelMode.WALKING,
unitSystem: google.maps.UnitSystem.METRIC,
avoidHighways: false,
avoidTolls: false
}, callback);
}
function callback(response, status) {
var dist=[];
if (status != google.maps.DistanceMatrixStatus.OK) {
alert('Error was: ' + status);
} else {
var origins = response.originAddresses;
var destinations = response.destinationAddresses;
var outputDiv = document.getElementById('directions_panel');
outputDiv.innerHTML = '';
var results = response.rows[0].elements;
for (var k = 0; k < results.length; k++) {
var zws=results[k].distance.text;
zws=zws.split(" ");
zws=parseFloat(zws[0]);
dist.push(zws);
}
var index=[];
var min=[];
for (var j = 0; j < dist.length; j++) {
if(j==0){
min.push(dist[0]);
index.push(0);
}
else if(dist[j]<min[0]){
min=[];
index=[];
min.push(dist[j]);
index.push(j);
}
else if(dist[j]==min[0]){
min.push(dist[j]);
index.push(j);
}
else{
continue;
}
}
for (var l = 0; l < index.length; l++) {
outputDiv.innerHTML += 'Your entered adress: '+origins[0]+ '<br>';
outputDiv.innerHTML += 'Your destination: '+destinations[index[l]]+ '<br>';
outputDiv.innerHTML += 'Distance: '+results[index[l]].distance.text+'<br>';
outputDiv.innerHTML += 'Estimated Time: '+results[index[l]].duration.text+'<br><br>';
}
}
}
google.maps.event.addDomListener(window, 'load', initialize);
</script>
</head>
<body>
<div id="routecalc">
</div>
<!-- HEADER -->
<div id="Header">
<img id="Logo" src="../styles/basic/Logo.gif" alt="Logo">
<img id="Headline" src="../styles/basic/Headline.gif" alt="Headline">
<a href="normalview.php"><img id="German" src="../styles/basic/german.png"></a>
<a href="normalview.php"><img id="English" src="../styles/basic/english.gif"></a>
</div>
<!-- MAP-->
<iframe id="Map" src="map/map.html">
<a href="map/map.html">OSM Maps</a>
</iframe>
<!-- SEARCH -->
<form id="Search" action="" method="post" name="form">
<p>Nächstgelegene Halle von
<input name="start" type="text" size="20" maxlength="30"/>
<input type="button"
value="Search"
onclick="calculateDistances(this.form.start);" />
</p>
</form>
<!--SEARCH RESULTS-->
<!-- FOOTER -->
<div id="directions_panel"></div>
</body>
</html>
欢迎克拉克斯