谷歌地图没有显示地图上的所有目的地标记,只有第一个和最后一个

google maps not showing all destination markers on map, only first and last

本文关键字:最后一个 第一个 显示 地图 谷歌地图 目的地      更新时间:2023-09-26

我有一个谷歌地图,可以用所有标记正确显示我的路线。https://jsfiddle.net/az5tk8ns/17/

目的地硬编码为:destinations = ["", "durban,KZN", " ixpop,kzn"]

然后,我有另一个函数,可以生成我的地址数组:

var addresses = [];
addresses.push('Durban, KZN');
addresses.push('izopo, KZN');`

然后我设置:

destinations = addresses

https://jsfiddle.net/az5tk8ns/19/

当这样做的时候,地图只显示开始和结束的目的地标记,而不是我在中间的停止?

我如何使用这种方法,以便将动态生成的地址数组传递到谷歌地图,并让它显示旅程中的每一点?

完整的谷歌地图语法:

$(document).ready(function() {

var directionsDisplay;
var directionsService = new google.maps.DirectionsService();
var map;
var distancearray=[];
var addresses = [];
addresses.push('Durban, KZN');
addresses.push('izopo, KZN');
warehouse='ladysmith, kwa zulu natal';

function initialize() {
  directionsDisplay = new google.maps.DirectionsRenderer();
  var chicago = new google.maps.LatLng(-28.5710903, 26.0826083);
  var mapOptions = {
    zoom: 7,
    center: chicago
  };
  map = new google.maps.Map(document.getElementById('route_map_canvas'), mapOptions);
  directionsDisplay.setMap(map);
  calcRoute();
}
var origin = "johannesburg",
  destinations = addresses
service = new google.maps.DistanceMatrixService();
function calcRoute() {
  var waypts = [];
  for (var i = 1; i < destinations.length - 1; i++) {
    waypts.push({
      location: destinations[i],
      stopover: true
    });
  }
  var request = {
    origin: origin,
    destination: destinations[destinations.length - 1],
    waypoints: waypts,
    optimizeWaypoints: true,
    travelMode: google.maps.TravelMode.DRIVING
  };
  directionsService.route(request, function(response, status) {
    if (status == google.maps.DirectionsStatus.OK) {
      directionsDisplay.setDirections(response);
      var orig = document.getElementById("orig"),
        dest = document.getElementById("dest"),
        dist = document.getElementById("dist");
      orig.value = response.routes[0].legs[0].start_address;
      dest.value = response.routes[0].legs[0].end_address;
      var total_distance = 0.0;
      for (var i = 0; i < response.routes[0].legs.length; i++) {
        total_distance += response.routes[0].legs[i].distance.value;
        distancearray.push([response.routes[0].legs[i].distance.value]);
        //alert(distancearray);
      }
      dist.value = total_distance + " meters";
    }
  });
}
  initialize();
})

一如既往地感谢

除了destinations变量中只有两个用作开始和结束的目的地之外,您已经完成了所有正确的操作。calcRoute()函数中的directionsRequest对象中没有路点。这就是你没有得到任何中间路线点,因此没有标记的原因。

请参阅这个更新的Fiddle,我在其中向addresses变量(行号11)又推了一个位置,它在地图上正确显示。

您总是可以执行console.log(request);来查看您要传递给google的请求对象。