【问题标题】:Google Maps API v3: Driving directions over a map which first loads 2 positionsGoogle Maps API v3:首先加载 2 个位置的地图上的行车路线
【发布时间】:2013-04-23 19:03:46
【问题描述】:

我有一张地图,它显示两个带有标记的位置(并自动在这两个位置之间居中),你可以在这里看到它:http://goo.gl/rRDCE 我正在尝试将它与方向服务集成,就像这个演示一样:https://developers.google.com/maps/documentation/javascript/examples/directions-simple

地图应该首先加载 2 个位置标记,然后如果用户选择一个起点,它应该显示到 2 个位置之一的方向。

这是我到目前为止所拥有的(当然不起作用,地图没有加载)......:P http://jsfiddle.net/multiformeingegno/fhAJA/5/

JAVASCRIPT

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);

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>

我做错了什么? :)

【问题讨论】:

  • 位置数组元素的第一个元素中的字符串缺少右引号?或者这是一个错字...
  • 这里是一个错字。已修复,但不是问题所在。 :D

标签: javascript html google-maps-api-3 maps


【解决方案1】:

您缺少 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);

working fiddle(已更新,因此方向有效,至少从意大利的位置)

【讨论】:

  • 谢谢,这确实是一个进步。 :) 我的代码授予每个缩放级别设置的 2 个位置始终居中。看看这里的脚本:goo.gl/rRDCE
  • 不幸的是,在选择开始/结束位置时没有计算方向..
  • 这并不让我吃惊,你无法获得从美国到罗马的行车路线
  • 嘿嘿对了!我会尝试更改这些地址,看看它是否有效:D
  • jsfiddle 包装 javascript 也存在问题,因此 calcRoute 在全局范围内不可用:jsfiddle.net/fhAJA/8
猜你喜欢
  • 2012-07-29
  • 2011-06-18
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-09-03
  • 2013-07-13
相关资源
最近更新 更多