AI-generated Key Takeaways
- 
          Intermediate waypoints can be designated as pass-through points using the viaproperty to avoid unnecessary stops.
- 
          Setting viatotrueallows for a more direct route, but may result in detours or route calculation failures if the waypoint is inaccessible.
- 
          When using address strings or Plus codes for waypoints, the API returns place IDs for these locations in the geocodingResultsarray.
- 
          The geocodingResultsarray helps identify the place IDs of waypoints, which can be useful for subsequent requests or analysis.
- 
          Waypoints specified using latitude/longitude coordinates or place IDs are excluded from the geocodingResultsarray.
By default, intermediate waypoints are used for stopping for pickups and dropoffs, but you can also specify that an intermediate waypoint is meant just to pass through.
A route that contains an origin waypoint, a pass-through intermediate
waypoint, and a destination waypoint contains just one route leg that
connects the origin and the destination, while passing through the intermediate
(called a via) waypoint.
Configure an intermediate waypoint to be a pass-through waypoint by
setting the via property of the waypoint to true using either
Waypoint (REST) or
Waypoint (gRPC).
The via property is most effective when creating routes in response to
the user dragging the waypoints on the map. Doing so allows the user to see how
the final route may look in real-time and helps ensure that waypoints are placed
in locations that are accessible to the Compute Routes.
The following example demonstrates how to mark an intermediate waypoint as a pass-through waypoint.
{ "location": { "latLng": { "latitude":37.419734, "longitude":-122.0827784 } }, "via": true }
Access place IDs for intermediate waypoints
If you specify the location of an origin, destination, or intermediate waypoint
as an address string or as a Plus code, the API attempts to find the
most relevant location which has a corresponding place ID. The
geocodingResults.intermediates
array in the results contains the place ID corresponding to the location of the
waypoints, along with additional data about the location.
For each element of the intermediates array, use the
intermediateWaypointRequestIndex property to determine which intermediate
waypoint in the request corresponds to the place ID in the response.
For example:
- You specify three intermediate waypoints in a request. Two of these waypoints are specified by address strings and one by latitude/longitude coordinates. 
- You include - geocodingResultsin the response field mask to specify to return the- geocodingResultsarray in the results.
curl -X POST -d '{ "origin":{ "address": "1600 Amphitheatre Parkway, Mountain View, CA" }, "destination":{ "address": "24 Willie Mays Plaza, San Francisco, CA 94107" }, "intermediates": [ { "address": "450 Serra Mall, Stanford, CA 94305, USA" }, { "location":{ "latLng":{ "latitude": 37.419734, "longitude": -122.0807784 } } }, { "address": "1836 El Camino Real, Redwood City, CA 94063" } ], "travelMode": "DRIVE", }' -H 'Content-Type: application/json' -H 'X-Goog-Api-Key: YOUR_API_KEY' -H 'X-Goog-FieldMask: routes.duration,routes.distanceMeters,routes.legs,geocodingResults' 'https://routes.googleapis.com/directions/v2:computeRoutes'
The response includes the geocodingResults array containing the place ID for
the origin, destination, and for two of the three waypoints. These are the
waypoints at index 0 and 2 of the request. Because the waypoint at index 1 of
the request was specified by using latitude/longitude coordinates, it is
omitted from the geocodingResults array in the response.
{ "routes": [{...}], "geocodingResults": { "origin": { "geocoderStatus": {}, "type": [ "premise" ], "placeId": "ChIJj38IfwK6j4ARNcyPDnEGa9g" }, "destination": { "geocoderStatus": {}, "type": [ "premise" ], "placeId": "ChIJI7ES6tl_j4ARVpDZoXbWAiY" }, "intermediates": [ { "geocoderStatus": {}, "intermediateWaypointRequestIndex": 0, "type": [ "street_address" ], "placeId": "ChIJvdLMGyq7j4ARScE5tWX_C0Y" }, { "geocoderStatus": {}, "intermediateWaypointRequestIndex": 2, "type": [ "premise" ], "placeId": "ChIJkTc0GKajj4AR9UMsOSHwGD0" } ] } }