Javascript GoogleMapsAPIv3:首先加载2个位置的地图上的驾驶方向
我有一张地图,其中显示了两个带有标记的位置(并自动在这两个位置之间居中),您可以在这里看到它: 我正在尝试将其与方向服务集成,就像这个演示: 地图应首先加载2个位置标记,然后如果用户选择起点,则应显示指向2个位置之一的方向 这是我到目前为止所拥有的(当然不起作用,地图没有加载)P JAVASCRIPTJavascript GoogleMapsAPIv3:首先加载2个位置的地图上的驾驶方向,javascript,html,google-maps-api-3,maps,Javascript,Html,Google Maps Api 3,Maps,我有一张地图,其中显示了两个带有标记的位置(并自动在这两个位置之间居中),您可以在这里看到它: 我正在尝试将其与方向服务集成,就像这个演示: 地图应首先加载2个位置标记,然后如果用户选择起点,则应显示指向2个位置之一的方向 这是我到目前为止所拥有的(当然不起作用,地图没有加载)P JAVASCRIPT var directionsDisplay; var directionsService = new google.maps.DirectionsService(); var map; fun
var directionsDisplay;
var directionsService = new google.maps.DirectionsService();
var map;
function initialize() {
directionsDisplay = new google.maps.DirectionsRenderer();
var locations = [
['Place 1', 41.897467, 12.470364, 2],
['Place 2', 41.896561, 12.467792, 1]
];
var infowindow = new google.maps.InfoWindow();
var bounds = new google.maps.LatLngBounds();
for (i = 0; i < locations.length; i++) {
marker = new google.maps.Marker({
position: new google.maps.LatLng(locations[i][1], locations[i][2]),
map: map
});
bounds.extend(marker.position);
google.maps.event.addListener(marker, 'click', (function (marker, i) {
return function () {
infowindow.setContent(locations[i][0]);
infowindow.open(map, marker);
}
})(marker, i));
}
map.fitBounds(bounds);
var listener = google.maps.event.addListener(map, "idle", function () {
map.setZoom(17);
google.maps.event.removeListener(listener);
});
directionsDisplay.setMap(map);
}
function calcRoute() {
var start = document.getElementById('start').value;
var end = document.getElementById('end').value;
var request = {
origin: start,
destination: end,
travelMode: google.maps.DirectionsTravelMode.DRIVING
};
directionsService.route(request, function (response, status) {
if (status == google.maps.DirectionsStatus.OK) {
directionsDisplay.setDirections(response);
}
});
}
google.maps.event.addDomListener(window, 'load', initialize);
var方向显示;
var directionsService=new google.maps.directionsService();
var映射;
函数初始化(){
directionsDisplay=new google.maps.DirectionsRenderer();
变量位置=[
[Place1',41.897467,12.470364,2],
[Place2',41.896561,12.467792,1]
];
var infowindow=new google.maps.infowindow();
var bounds=new google.maps.LatLngBounds();
对于(i=0;i
HTML:
<script src="https://maps.googleapis.com/maps/api/js?v=3.exp&sensor=false"></script>
<b>Start: </b>
<select id="start" onchange="calcRoute();">
<option value="chicago, il">Chicago</option>
<option value="st louis, mo">St Louis</option>
<option value="joplin, mo">Joplin, MO</option>
<option value="oklahoma city, ok">Oklahoma City</option>
<option value="amarillo, tx">Amarillo</option>
<option value="gallup, nm">Gallup, NM</option>
<option value="flagstaff, az">Flagstaff, AZ</option>
<option value="winona, az">Winona</option>
<option value="kingman, az">Kingman</option>
<option value="barstow, ca">Barstow</option>
<option value="san bernardino, ca">San Bernardino</option>
<option value="los angeles, ca">Los Angeles</option>
</select> <b>End: </b>
<select id="end" onchange="calcRoute();">
<option value="41.897467, 12.470364">Place 1</option>
<option value="41.896561, 12.467792">Place 2</option>
</select>
<div id="map" style="position:relative;width:500px;height:300px"></div>
开始:
芝加哥
圣路易斯
密苏里州乔普林
俄克拉荷马城
阿马里洛
盖洛普
亚利桑那州弗拉格斯塔夫
维诺娜
金门
巴斯托
圣贝纳迪诺
洛杉矶
完:
地点1
地点2
我做错了什么?:) 您缺少一个google.maps.Map对象。小提琴没有正确包含API脚本:
var myOptions = {
zoom: 10,
center: new google.maps.LatLng(-33.9, 151.2),
mapTypeControl: true,
mapTypeControlOptions: {style: google.maps.MapTypeControlStyle.DROPDOWN_MENU},
navigationControl: true,
mapTypeId: google.maps.MapTypeId.ROADMAP
}
map = new google.maps.Map(document.getElementById("map"),
myOptions);
(至少在意大利的位置更新了方向)位置数组元素的第一个元素中的字符串缺少右引号?或者这是一个打字错误……这是一个打字错误。已修复,但这不是问题所在:汉克斯,这确实是向前迈出的一步我的代码允许设置每个缩放级别时,两个位置始终居中。看一下这里的脚本:不幸的是,在选择起点/终点位置时没有计算方向。这并不奇怪,你无法正确获得从美国到罗密欧的驾驶方向!我将尝试更改这些地址,看看它是否有效:数据JSFIDLE包装javascript时也存在问题,因此calcRoute在全局范围内不可用: