Use one waypoint as destination in Gmaps Api

后端 未结 1 1747
北恋
北恋 2021-01-27 06:00

I\'m using gmaps Api to make a route for a person who have to visit a list of markets (my waypoints) to take note of their stocks. I\'m using the user\'s house location for the

相关标签:
1条回答
  • 2021-01-27 06:54

    You could make multiple requests to the directions service, one with each possible waypoint as the final destination, pick the shortest resulting distance.

    proof of concept fiddle

    code snippet:

    var map;
    var directionsServices = [];
    var directionsDisplays = [];
    // constant "start" address
    var start = "Paramus, NJ";
    // list of possible candidate destinations/waypoints (must be < 9)
    var locations = ["67 E Ridgewood Ave, Paramus, NJ 07652",
      "450 Rochelle Ave, Rochelle Park, NJ 07662,",
      "720 River Rd, New Milford, NJ 07646",
      "280 Main St, New Milford, NJ 07646",
      "469 Passaic St, Hackensack, NJ 07601",
      "91 Broadway, Elmwood Park, NJ 07407",
      "206 Market St, Saddle Brook, NJ 07662"
    ];
    var routes = [];
    
    function initialize() {
      var map = new google.maps.Map(
        document.getElementById("map_canvas"), {
          center: new google.maps.LatLng(37.4419, -122.1419),
          zoom: 13,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        });
      document.getElementById('info').innerHTML += "<u><b>intermediate results:</b></u><br>";
      getDirections(start, locations, map);
    }
    google.maps.event.addDomListener(window, "load", initialize);
    
    function getDirections(start, waypoints, map) {
      var requests = [];
      var request = {
        origin: start,
        optimizeWaypoints: true,
        travelMode: google.maps.TravelMode.DRIVING
      };
      for (var j = 0; j < waypoints.length; j++) {
        var waypts = [];
        for (var i = 0; i < waypoints.length; i++) {
          if (i != j) {
            waypts.push({
              location: waypoints[i],
              stopover: true
            });
          }
        }
        requests[j] = {};
        requests[j].destination = waypoints[j];
        requests[j].waypoints = waypts;
        requests[j].origin = start;
        requests[j].optimizeWaypoints = true;
        requests[j].travelMode = google.maps.TravelMode.DRIVING;
    
        setTimeout(function(request, j) {
          sendDirectionsRequest(request, j, map);
        }(requests[j], j), 3000 * j);
      }
    }
    
    function sendDirectionsRequest(request, index, map) {
      var directionsService = new google.maps.DirectionsService();
      directionsServices.push(directionsService);
      directionsService.route(request, function(response, status) {
        if (status === google.maps.DirectionsStatus.OK) {
          var route = response.routes[0];
          routes.push(route);
          var distance = 0;
          var duration = 0;
          for (var i = 0; i < route.legs.length; i++) {
            distance += route.legs[i].distance.value;
            duration += route.legs[i].duration.value;
          }
          route.distance = distance;
          route.duration = duration;
          route.index = index;
          document.getElementById('info').innerHTML += (routes.length - 1) + " dist:" + (route.distance / 1000).toFixed(2) + " km dur:" + (route.duration / 60).toFixed(2) + " min dest:" + index + " loc:" + locations[index] + " waypt order:" + route.waypoint_order + "<br>";
          if (routes.length == locations.length) {
            routes.sort(sortFcn);
            var directionsDisplay = new google.maps.DirectionsRenderer({
              map: map,
              polylineOptions: {
                strokeOpacity: 0.9,
                strokeWeight: 4,
                strokeColor: "black",
                zIndex: 10
              }
            });
            directionsDisplay.setDirections(response);
            directionsDisplay.setMap(map);
            document.getElementById('info').innerHTML += "<u><b>shortest result:</b></u><br>" + routes[0].index + " dist:" + (routes[0].distance / 1000).toFixed(2) + " km dur:" + (routes[0].duration / 60).toFixed(2) + " min dest:" + routes[0].index + " loc:" + locations[index] + " waypt order:" + routes[0].waypoint_order + "<br>";
          }
        } else {
          window.alert('Directions request failed due to ' + status);
        }
      });
    }
    
    function sortFcn(a, b) {
      if (a.distance > b.distance) return 1;
      else if (a.distance < b.distance) return -1;
      else return 0;
    }
    html,
    body,
    #map_canvas {
      height: 100%;
      width: 100%;
      margin: 0px;
      padding: 0px
    }
    <script src="https://maps.googleapis.com/maps/api/js"></script>
    <div id="info"></div>
    <div id="map_canvas"></div>

    0 讨论(0)
提交回复
热议问题