This service is also available as part of the Google Maps JavaScript API, or with a Java client library.
Introduction
The Google Directions API is a service that calculates directions between locations using an HTTP request. You can search for directions for several modes of transportation, include transit, driving, walking or cycling. Directions may specify origins, destinations and waypoints either as text strings (e.g. "Chicago, IL" or "Darwin, NT, Australia") or as latitude/longitude coordinates. The Directions API can return multi-part directions using a series of waypoints.
This service is generally designed for calculating directions for static (known in advance) addresses for placement of application content on a map; this service is not designed to respond in real time to user input, for example. For dynamic directions calculations (for example, within a user interface element), consult the documentation for the JavaScript API V3 Directions Service.
Calculating directions is a time and resource intensive task. Whenever possible, calculate known addresses ahead of time (using the service described here) and store your results in a temporary cache of your own design.
Audience
This document is intended for website and mobile developers who want to compute direction data within maps provided by one of the Google Maps APIs. It provides an introduction to using the API and reference material on the available parameters.
API Key
Note: Maps for Work users must include
client
and signature parameters with their requests instead of a key.
All Directions API applications should use an API key. Including a key in your request:
- Allows you to monitor your application's API usage in the Google Developers Console.
- Enables per-key instead of per-IP-address quota limits.
- Ensures that Google can contact you about your application if necessary.
The Directions API uses an API key to identify your application. API keys are managed through the Google APIs console. To create your key:
- Visit the APIs console at Google Developers Console and log in with your Google Account.
- Click the Services link from the left-hand menu in the APIs Console, then activate the Directions API service.
- Once the service has been activated, your API key is available from the API Access page, in the Simple API Access section. Directions API applications use the Key for server apps.
To specify a key in your request, include it as the value of a
key parameter.
Note: By default, a key can be used from any server. We strongly recommend that you restrict the use of your key by IP address to servers that you administer. You can specify which IP addresses are allowed to use your API key by clicking the Edit allowed referers... link in the API console.
Note: HTTPS is enforced for requests that include an API key.
Usage Limits
The Directions API has the following limits in place:
- Users of the free API:
-
- 2,500 directions requests per 24 hour period.
- Up to 8 waypoints allowed in each request. Waypoints are not available for transit directions.
- 2 requests per second.
- Google Maps API for Work customers:
-
- 100,000 directions requests per 24 hour period.
- 23 waypoints allowed in each request. Waypoints are not available for transit directions.
- 10 requests per second.
Directions API URLs are restricted to approximately 2000 characters, after URL Encoding. As some Directions API URLs may involve many locations along a path, be aware of this limit when constructing your URLs.
The Directions API may only be used in conjunction with displaying results on a Google map; using Directions data without displaying a map for which directions data was requested is prohibited. Additionally, calculation of directions generates copyrights and warnings which must be displayed to the user in some fashion. For complete details on allowed usage, consult the Maps API Terms of Service License Restrictions.
Directions Requests
A Directions API request takes the following form:
https://maps.googleapis.com/maps/api/directions/output?parameters
where output may be either of the following values:
json(recommended) indicates output in JavaScript Object Notation (JSON)xmlindicates output as XML
To access the Directions API over HTTP, use:
http://maps.googleapis.com/maps/api/directions/output?parameters
HTTPS is recommended for applications that include sensitive user data, such as a user's location, in requests.
Request Parameters
Certain parameters are required while others are optional. As is
standard in URLs, all parameters are separated using the ampersand
(&) character. The list of parameters and their possible
values are enumerated below.
Required parameters
origin— The address or textual latitude/longitude value from which you wish to calculate directions. If you pass an address as a string, the Directions service will geocode the string and convert it to a latitude/longitude coordinate to calculate directions. If you pass coordinates, ensure that no space exists between the latitude and longitude values.destination— The address or textual latitude/longitude value from which you wish to calculate directions. If you pass an address as a string, the Directions service will geocode the string and convert it to a latitude/longitude coordinate to calculate directions. If you pass coordinates, ensure that no space exists between the latitude and longitude values.
Google Maps API for Work users must include valid client and
signature parameters with their Directions requests. Please refer
to the Google Maps API for Work Web Services chapter for more information.
Optional parameters
mode(defaults todriving) — Specifies the mode of transport to use when calculating directions. Valid values and other request details are specified in Travel Modes.waypoints— Specifies an array of waypoints. Waypoints alter a route by routing it through the specified location(s). A waypoint is specified as either a latitude/longitude coordinate or as an address which will be geocoded. Waypoints are only supported for driving, walking and bicycling directions. (For more information on waypoints, see Using Waypoints in Routes below.)alternatives— If set totrue, specifies that the Directions service may provide more than one route alternative in the response. Note that providing route alternatives may increase the response time from the server.avoid— Indicates that the calculated route(s) should avoid the indicated features. This parameter supports the following arguments:tollsindicates that the calculated route should avoid toll roads/bridges.highwaysindicates that the calculated route should avoid highways.ferriesindicates that the calculated route should avoid ferries.
language— Specifies the language in which to return results. See the list of supported domain languages. Note that we often update supported languages so this list may not be exhaustive. Iflanguageis not supplied, the service will attempt to use the native language of the domain from which the request is sent.units— Specifies the unit system to use when displaying results. Valid values are specified in Unit Systems below.region— Specifies the region code, specified as a ccTLD ("top-level domain") two-character value. (For more information see Region Biasing below.)departure_time— Specifies the desired time of departure. You can specify the time as an integer in seconds since midnight, January 1, 1970 UTC. Alternatively, you can specify a value ofnow, which sets the departure time to the current time (correct to the nearest second). The departure time may be specified in two cases:- For transit directions: You can optionally specify one of
departure_timeorarrival_time. If neither time is specified, thedeparture_timedefaults to now (that is, the departure time defaults to the current time). - For driving directions: Google Maps API for Work customers
can specify the
departure_timeto receive trip duration considering current traffic conditions. Thedeparture_timemust be set to within a few minutes of the current time.
- For transit directions: You can optionally specify one of
arrival_time— Specifies the desired time of arrival for transit directions, in seconds since midnight, January 1, 1970 UTC. You can specify eitherdeparture_timeorarrival_time, but not both. Note thatarrival_timemust be specified as an integer.transit_mode— Specifies one or more preferred modes of transit. This parameter may only be specified for transit directions, and only if the request includes an API key or a Google Maps API for Work client ID. The parameter supports the following arguments:busindicates that the calculated route should prefer travel by bus.subwayindicates that the calculated route should prefer travel by subway.trainindicates that the calculated route should prefer travel by train.tramindicates that the calculated route should prefer travel by tram and light rail.railindicates that the calculated route should prefer travel by train, tram, light rail, and subway. This is equivalent totransit_mode=train|tram|subway.
transit_routing_preference— Specifies preferences for transit routes. Using this parameter, you can bias the options returned, rather than accepting the default best route chosen by the API. This parameter may only be specified for transit directions, and only if the request includes an API key or a Google Maps API for Work client ID. The parameter supports the following arguments:less_walkingindicates that the calculated route should prefer limited amounts of walking.fewer_transfersindicates that the calculated route should prefer a limited number of transfers.
Example Directions Requests
The following request returns driving directions from Toronto, Ontario to Montreal, Quebec.
https://maps.googleapis.com/maps/api/directions/json?origin=Toronto&destination;=Montreal&key=API_KEY
By changing the mode and avoid parameters,
the initial request can be modified to return directions for a
scenic bicycle journey that avoids major highways.
https://maps.googleapis.com/maps/api/directions/json?origin=Toronto&destination;=Montreal&avoid;=highways&mode;=bicycling&key=API_KEY
The following request searches for transit directions from Brooklyn, New York
to Queens, New York. The request does not specify a
departure_time, so the departure time defaults to the current
time:
https://maps.googleapis.com/maps/api/directions/json?origin=Brooklyn&destination;=Queens&mode;=transit&key=API_KEY
The following request includes a specific departure time.
Note: In this example the departure time is specified as July 30, 2012 at 09:45 am. To avoid an error, you must change the parameter to a time in the future before submitting the request.
https://maps.googleapis.com/maps/api/directions/json?origin=Brooklyn&destination;=Queens&departure_time=1343641500&mode;=transit&key=API_KEY
Travel Modes
When you calculate directions, you may specify
the transportation mode to use. By default,
directions are calculated as driving directions. The following
travel modes are supported:
driving(default) indicates standard driving directions using the road network.walkingrequests walking directions via pedestrian paths & sidewalks (where available).bicyclingrequests bicycling directions via bicycle paths & preferred streets (where available).transitrequests directions via public transit routes (where available). If you set the mode totransit, you can optionally specify either adeparture_timeor anarrival_time. If neither time is specified, thedeparture_timedefaults to now (that is, the departure time defaults to the current time). You can also optionally include atransit_modeand/or atransit_routing_preference.
Note: Both walking and
bicycling directions may sometimes not include clear pedestrian or
bicycling paths, so these directions will return warnings
in the returned result which you must display to the user.
Using Waypoints in Routes
When calculating routes using the Directions API, you may also specify waypoints for driving, walking or bicycling directions. Waypoints are not available for transit directions. Waypoints allow you to calculate routes through additional locations, in which case the returned route passes through the given waypoints.
Waypoints are specified within the waypoints
parameter and consist of one or more addresses or locations
separated by the pipe (|) character.
For example, the following URL initiates a Directions request for a route between Boston, MA and Concord, MA with stopovers in Charlestown and Lexington, in that order:
https://maps.googleapis.com/maps/api/directions/json?origin=Boston,MA&destination=Concord,MA&waypoints=Charlestown,MA|Lexington,MA&key=API_KEY
You can use waypoints to influence your route without adding a
stopover by prefixing the waypoint with via:. Waypoints
prefixed with via: will not add an additional leg to the route.
The following URL modifies the previous request such that you are routed through Lexington without stopping:
https://maps.googleapis.com/maps/api/directions/json?origin=Boston,MA&destination=Concord,MA&waypoints=Charlestown,MA|via:Lexington,MA&key=API_KEY
By default, the Directions service calculates a route through
the provided waypoints in their given order. Optionally, you
may pass optimize:true as the first argument
within the waypoints parameter to allow the Directions
service to optimize the provided route by rearranging the waypoints in
a more efficient order. (This optimization is an application of the
Travelling Salesman Problem.)
If you instruct the Directions service to optimize the order of
its waypoints, their order will be returned in the
waypoint_order field within the
routes object. The waypoint_order field
returns values which are zero-based.
The following example calculates a road trip route from Adelaide, South Australia to each of South Australia's main wine regions using route optimization.
https://maps.googleapis.com/maps/api/directions/json?origin=Adelaide,SA&destination=Adelaide,SA&waypoints=optimize:true|Barossa+Valley,SA|Clare,SA|Connawarra,SA|McLaren+Vale,SA&key=API_KEY
Inspection of the calculated route will indicate that the route is calculated using the following waypoint order:
"waypoint_order": [ 1, 0, 2, 3 ]
Restrictions
Directions may be calculated that adhere to certain restrictions. Restrictions
are indicated by use of the avoid parameter, and an argument to that
parameter indicating the restriction to avoid. The following restrictions are supported:
avoid=tollsavoid=highwaysavoid=ferries
It's possible to request a route that avoids any combination of tolls, highways and ferries by
passing both restrictions to the avoid parameter. For example:
avoid=tolls|highways|ferries.
Note: the addition of restrictions does not preclude routes that include the restricted feature; it simply biases the result to more favorable routes.
Unit Systems
Directions results contain text within distance
fields that may be displayed to the user to indicate the distance of a
particular "step" of the route. By default, this text uses the unit system
of the origin's country or region.
For example, a route from
"Chicago, IL" to "Toronto, ONT" will display results in miles, while
the reverse route will display results in kilometers. You
may override this unit system by setting one explicitly within the
request's units parameter, passing one of the following
values:
metricspecifies usage of the metric system. Textual distances are returned using kilometers and meters.imperialspecifies usage of the Imperial (English) system. Textual distances are returned using miles and feet.
Note: this unit system setting only
affects the text displayed within distance
fields. The distance fields also contain values
which are always expressed in meters.
Region Biasing
You can also set the Directions service to return results biased to a
particular region by use of the region parameter. This parameter
takes a ccTLD (country code
top-level domain) argument specifying the region bias. Most ccTLD codes are
identical to ISO 3166-1 codes, with some notable exceptions. For example,
the United Kingdom's ccTLD is "uk" (.co.uk) while its ISO 3166-1
code is "gb" (technically for the entity of "The United Kingdom of Great
Britain and Northern Ireland").
You may utilize any domain in which the main Google Maps application has launched driving directions.
For example, a directions request from "Toldeo" to "Madrid"
returns a result when region is set to es
as "Toledo" is interpreted as the Spanish city:
https://maps.googleapis.com/maps/api/directions/json?origin=Toledo&destination=Madrid®ion=es&key=API_KEY
{
"status": "OK",
"routes": [ {
"summary": "AP-41",
"legs": [ {
...
} ],
"copyrights": "Map data ©2010 Europa Technologies, Tele Atlas",
"warnings": [ ],
"waypoint_order": [ ]
} ]
}
A directions for "Toledo" to "Madrid" sent to with no region
parameter will not return any results, since "Toledo" is interpreted as the
city in Ohio:
https://maps.googleapis.com/maps/api/directions/json?origin=Toledo&destination=Madrid&key=API_KEY
{
"status": "ZERO_RESULTS",
"routes": [ ]
}
Directions Responses
Directions responses are returned in the format indicated by the
output flag within the URL request's path.
Sample Responses
A sample HTTP request is shown below, calculating the route from Chicago, IL to Los Angeles, CA via two waypoints in Joplin, MO and Oklahoma City, OK.
https://maps.googleapis.com/maps/api/directions/json?origin=Chicago,IL&destination=Los+Angeles,CA&waypoints=Joplin,MO|Oklahoma+City,OK&key=API_KEY
The above example requests JSON output. It's also possible to request XML output. Click the tabs below to see the sample JSON and XML responses.
Because directions results can be quite verbose, repeated elements within the responses have been omitted for clarity.
{
"status": "OK",
"routes": [ {
"summary": "I-40 W",
"legs": [ {
"steps": [ {
"travel_mode": "DRIVING",
"start_location": {
"lat": 41.8507300,
"lng": -87.6512600
},
"end_location": {
"lat": 41.8525800,
"lng": -87.6514100
},
"polyline": {
"points": "a~l~Fjk~uOwHJy@P"
},
"duration": {
"value": 19,
"text": "1 min"
},
"html_instructions": "Head \u003cb\u003enorth\u003c/b\u003e on \u003cb\u003eS Morgan St\u003c/b\u003e toward \u003cb\u003eW Cermak Rd\u003c/b\u003e",
"distance": {
"value": 207,
"text": "0.1 mi"
}
},
...
... additional steps of this leg
...
... additional legs of this route
"duration": {
"value": 74384,
"text": "20 hours 40 mins"
},
"distance": {
"value": 2137146,
"text": "1,328 mi"
},
"start_location": {
"lat": 35.4675602,
"lng": -97.5164276
},
"end_location": {
"lat": 34.0522342,
"lng": -118.2436849
},
"start_address": "Oklahoma City, OK, USA",
"end_address": "Los Angeles, CA, USA"
} ],
"copyrights": "Map data ©2010 Google, Sanborn",
"overview_polyline": {
"points": "a~l~Fjk~uOnzh@vlbBtc~@tsE`vnApw{A`dw@~w\\|tNtqf@l{Yd_Fblh@rxo@b}@xxSfytAblk@xxaBeJxlcBb~t@zbh@jc|Bx}C`rv@rw|@rlhA~dVzeo@vrSnc}Axf]fjz@xfFbw~@dz{A~d{A|zOxbrBbdUvpo@`cFp~xBc`Hk@nurDznmFfwMbwz@bbl@lq~@loPpxq@bw_@v|{CbtY~jGqeMb{iF|n\\~mbDzeVh_Wr|Efc\\x`Ij{kE}mAb~uF{cNd}xBjp]fulBiwJpgg@|kHntyArpb@bijCk_Kv~eGyqTj_|@`uV`k|DcsNdwxAott@r}q@_gc@nu`CnvHx`k@dse@j|p@zpiAp|gEicy@`omFvaErfo@igQxnlApqGze~AsyRzrjAb__@ftyB}pIlo_BflmA~yQftNboWzoAlzp@mz`@|}_@fda@jakEitAn{fB_a]lexClshBtmqAdmY_hLxiZd~XtaBndgC"
},
"warnings": [ ],
"waypoint_order": [ 0, 1 ],
"bounds": {
"southwest": {
"lat": 34.0523600,
"lng": -118.2435600
},
"northeast": {
"lat": 41.8781100,
"lng": -87.6297900
}
}
} ]
}
Generally, only one entry in the routes array is returned
for directions lookups, though the Directions service may return several routes
if you pass alternatives=true.
Note that these results generally need to be parsed if you wish to extract values from the results. Parsing JSON is relatively easy. See Parsing JSON for some recommended design patterns.
<DirectionsResponse>
<status>OK</status>
<route>
<summary>I-40 W</summary>
<leg>
<step>
<travel_mode>DRIVING</travel_mode>
<start_location>
<lat>41.8507300</lat>
<lng>-87.6512600</lng>
</start_location>
<end_location>
<lat>41.8525800</lat>
<lng>-87.6514100</lng>
</end_location>
<polyline>
<points>a~l~Fjk~uOwHJy@P</points>
</polyline>
<duration>
<value>19</value>
<text>1 min</text>
</duration>
<html_instructions>Head <b>north</b> on <b>S Morgan St</b> toward <b>W Cermak Rd</b></html_instructions>
<distance>
<value>207</value>
<text>0.1 mi</text>
</distance>
</step>
...
... additional steps of this leg
...
... additional legs of this route
<duration>
<value>74384</value>
<text>20 hours 40 mins</text>
</duration>
<distance>
<value>2137146</value>
<text>1,328 mi</text>
</distance>
<start_location>
<lat>35.4675602</lat>
<lng>-97.5164276</lng>
</start_location>
<end_location>
<lat>34.0522342</lat>
<lng>-118.2436849</lng>
</end_location>
<start_address>Oklahoma City, OK, USA</start_address>
<end_address>Los Angeles, CA, USA</end_address>
<copyrights>Map data ©2010 Google, Sanborn</copyrights>
<overview_polyline>
<points>a~l~Fjk~uOnzh@vlbBtc~@tsE`vnApw{A`dw@~w\|tNtqf@l{Yd_Fblh@rxo@b}@xxSfytAblk@xxaBeJxlcBb~t@zbh@jc|Bx}C`rv@rw|@rlhA~dVzeo@vrSnc}Axf]fjz@xfFbw~@dz{A~d{A|zOxbrBbdUvpo@`cFp~xBc`Hk@nurDznmFfwMbwz@bbl@lq~@loPpxq@bw_@v|{CbtY~jGqeMb{iF|n\~mbDzeVh_Wr|Efc\x`Ij{kE}mAb~uF{cNd}xBjp]fulBiwJpgg@|kHntyArpb@bijCk_Kv~eGyqTj_|@`uV`k|DcsNdwxAott@r}q@_gc@nu`CnvHx`k@dse@j|p@zpiAp|gEicy@`omFvaErfo@igQxnlApqGze~AsyRzrjAb__@ftyB}pIlo_BflmA~yQftNboWzoAlzp@mz`@|}_@fda@jakEitAn{fB_a]lexClshBtmqAdmY_hLxiZd~XtaBndgC</points>
</overview_polyline>
<waypoint_index>0</waypoint_index>
<waypoint_index>1</waypoint_index>
<bounds>
<southwest>
<lat>34.0523600</lat>
<lng>-118.2435600</lng>
</southwest>
<northeast>
<lat>41.8781100</lat>
<lng>-87.6297900</lng>
</northeast>
</bounds>
</route>
</DirectionsResponse>
Note that the XML response consists of a single <DirectionsResponse>
and two top-level elements:
<status>contains metadata on the request. See Status Codes below.- Zero or more
<route>elements, each containing a single set of routing information between the origin and destination.
We recommend that you use json as the preferred output flag
unless your service requires xml for some reason. Processing XML
trees requires some care, so that you reference proper nodes and elements. See
Parsing XML
with XPath for some recommended design patterns for output processing.
The remainder of this documentation will use JSON syntax. In most cases, the output format does not matter for purposes of illustrating concepts or field names in the documentation. However, note the following subtle differences:
- XML results are wrapped in a root
<DirectionsResponse>element. - JSON denotes entries with multiple elements by plural arrays (
steps), while XML denotes these using multiple singular elements (<step>). - Blank elements are indicated through empty arrays in JSON, but by the absence of any
such element in XML. A response that generates no results will return an empty
routesarray in JSON, but no<route>elements in XML, for example.
Directions Response Elements
Directions responses contain two root elements:
statuscontains metadata on the request. See Status Codes below.routescontains an array of routes from the origin to the destination. See Routes below.
Routes consist of nested Legs and Steps.
Status Codes
The status field within the Directions response object contains the status
of the request, and may contain debugging information to help you track down why the
Directions service failed. The status field may contain the following
values:
OKindicates the response contains a validresult.NOT_FOUNDindicates at least one of the locations specified in the request's origin, destination, or waypoints could not be geocoded.ZERO_RESULTSindicates no route could be found between the origin and destination.MAX_WAYPOINTS_EXCEEDEDindicates that too manywaypointss were provided in the request The maximum allowedwaypointsis 8, plus the origin, and destination. ( Google Maps API for Work customers may contain requests with up to 23 waypoints.)INVALID_REQUESTindicates that the provided request was invalid. Common causes of this status include an invalid parameter or parameter value.OVER_QUERY_LIMITindicates the service has received too many requests from your application within the allowed time period.REQUEST_DENIEDindicates that the service denied use of the directions service by your application.UNKNOWN_ERRORindicates a directions request could not be processed due to a server error. The request may succeed if you try again.
Error Messages
When the status code is other than OK, there may be an additional
error_message field within the Directions response object. This field contains more
detailed information about the reasons behind the given status code.
Note: This field is not guaranteed to be always present, and its content is subject to change.
Routes
When the Directions API returns results, it places them
within a (JSON) routes array. Even if the service returns
no results (such as if the origin and/or destination doesn't exist) it
still returns an empty routes array. (XML responses consist
of zero or more <route> elements.)
Each element of the routes array contains a single result
from the specified origin and destination. This route may consist of
one or more legs depending on whether any waypoints
were specified. As well, the route also contains copyright and warning
information which must be displayed to the user in addition to the
routing information.
Each route within the routes field may contain
the following fields:
summarycontains a short textual description for the route, suitable for naming and disambiguating the route from alternatives.legs[]contains an array which contains information about a leg of the route, between two locations within the given route. A separate leg will be present for each waypoint or destination specified. (A route with no waypoints will contain exactly one leg within thelegsarray.) Each leg consists of a series ofsteps. (See Directions Legs below.)waypoint_ordercontains an array indicating the order of any waypoints in the calculated route. This waypoints may be reordered if the request was passedoptimize:truewithin itswaypointsparameter.overview_polylinecontains a singlepointsobject that holds an encoded polyline representation of the route. This polyline is an approximate (smoothed) path of the resulting directions.boundscontains the viewport bounding box of theoverview_polyline.copyrightscontains the copyrights text to be displayed for this route. You must handle and display this information yourself.warnings[]contains an array of warnings to be displayed when showing these directions. You must handle and display these warnings yourself.fare: If present, contains the total fare (that is, the total ticket costs) on this route. This property is only returned for transit requests and only for routes where fare information is available for all transit legs. The information includes:currency: An ISO 4217 currency code indicating the currency that the amount is expressed in.value: The total fare amount, in the currency specified above.
Below is an example of fare information within a route:
"routes" : [
{
"bounds" : {
"northeast" : {
"lat" : 37.8079996,
"lng" : -122.4074334
},
"southwest" : {
"lat" : 37.7881005,
"lng" : -122.4203553
}
},
"copyrights" : "Map data ©2015 Google",
"fare" : {
"currency" : "USD",
"value" : 6
},
...
}]
Legs
Each element in the legs array specifies a single leg
of the journey from the origin to the destination in the calculated
route. For routes that contain no waypoints, the route will consist
of a single "leg," but for routes that define one or more
waypoints, the route will consist of one or more legs, corresponding
to the specific legs of the journey.
Each leg within the legs field(s) may contain
the following fields:
steps[]contains an array of steps denoting information about each separate step of the leg of the journey. (See Directions Steps below.)distanceindicates the total distance covered by this leg, as a field with the following elements:valueindicates the distance in meterstextcontains a human-readable representation of the distance, displayed in units as used at the origin (or as overridden within theunitsparameter in the request). (For example, miles and feet will be used for any origin within the United States.) Note that regardless of what unit system is displayed as text, thedistance.valuefield always contains a value expressed in meters.
These fields may be absent if the distance is unknown.
durationindicates the total duration of this leg, as a field with the following elements:valueindicates the duration in seconds.textcontains a human-readable representation of the duration.
These fields may be absent if the duration is unknown.
duration_in_trafficindicates the total duration of this leg, taking into account current traffic conditions. The duration in traffic will only be returned if all of the following are true:- The directions request includes a
departure_timeparameter set to a value within a few minutes of the current time. - The request includes a valid Google Maps API for Work
clientandsignatureparameter. - Traffic conditions are available for the requested route.
- The directions request does not include stopover waypoints.
The
duration_in_trafficwill contain the following fields:valueindicates the duration in seconds.textcontains a human-readable representation of the duration.
- The directions request includes a
arrival_timecontains the estimated time of arrival for this leg. This property is only returned for transit directions. The result is returned as aTimeobject with three properties:valuethe time specified as a JavaScriptDateobject.textthe time specified as a string. The time is displayed in the time zone of the transit stop.time_zonecontains the time zone of this station. The value is the name of the time zone as defined in the IANA Time Zone Database, e.g. "America/New_York".
departure_timecontains the estimated time of departure for this leg, specified as aTimeobject. Thedeparture_timeis only available for transit directions.start_locationcontains the latitude/longitude coordinates of the origin of this leg. Because the Directions API calculates directions between locations by using the nearest transportation option (usually a road) at the start and end points,start_locationmay be different than the provided origin of this leg if, for example, a road is not near the origin.end_locationcontains the latitude/longitude coordinates of the given destination of this leg. Because the Directions API calculates directions between locations by using the nearest transportation option (usually a road) at the start and end points,end_locationmay be different than the provided destination of this leg if, for example, a road is not near the destination.start_addresscontains the human-readable address (typically a street address) reflecting thestart_locationof this leg.end_addresscontains the human-readable address (typically a street address) reflecting theend_locationof this leg.
Steps
Each element in the steps array defines a single step
of the calculated directions. A step is the most atomic unit of a
direction's route, containing a single step describing a specific, single
instruction on the journey. E.g. "Turn left at W. 4th St." The step not
only describes the instruction but also contains distance and duration
information relating to how this step relates to the following step.
For example, a step denoted as "Merge onto I-80 West" may contain a
duration of "37 miles" and "40 minutes," indicating that the next step
is 37 miles/40 minutes from this step.
When using the Directions API to search for transit directions, the steps
array will include additional transit details
in the form of a transit_details array. If the directions
include multiple modes of transportation, detailed directions will be
provided for walking or driving steps in an inner steps array.
For example, a walking step will include directions from the start and end
locations: "Walk to Innes Ave & Fitch St". That step will include
detailed walking directions for that route in the inner steps
array, such as: "Head north-west", "Turn left onto Arelious Walker", and
"Turn left onto Innes Ave".
Each step within the steps field(s) may contain
the following fields:
html_instructionscontains formatted instructions for this step, presented as an HTML text string.distancecontains the distance covered by this step until the next step. (See the discussion of this field in Directions Legs above.) This field may be undefined if the distance is unknown.durationcontains the typical time required to perform the step, until the next step. (See the description in Directions Legs above.) This field may be undefined if the duration is unknown.start_locationcontains the location of the starting point of this step, as a single set oflatandlngfields.end_locationcontains the location of the last point of this step, as a single set oflatandlngfields.polylinecontains a singlepointsobject that holds an encoded polyline representation of the step. This polyline is an approximate (smoothed) path of the step.stepscontains detailed directions for walking or driving steps in transit directions. Substeps are only available whentravel_modeis set to "transit". The innerstepsarray is of the same type assteps.transit_detailscontains transit specific information. This field is only returned withtravel_modeis set to "transit". See Transit Details below.
Transit Details
Transit directions return additional information that is not relevant for
other modes of transportation. These additional properties are exposed
through the transit_details object, returned as a field of
an element in the steps[] array. From the
TransitDetails object you can access additional information
about the transit stop, transit line and transit agency.
A transit_details object may contain the following fields:
arrival_stopanddeparture_stopcontains information about the stop/station for this part of the trip. Stop details can include:namethe name of the transit station/stop. eg. "Union Square".locationthe location of the transit station/stop, represented as alatandlngfield.
arrival_timeanddeparture_timecontain the arrival or departure times for this leg of the journey, specified as the following three properties:textthe time specified as a string. The time is displayed in the time zone of the transit stop.valuethe time specified as Unix time, or seconds since midnight, January 1, 1970 UTC.time_zonecontains the time zone of this station. The value is the name of the time zone as defined in the IANA Time Zone Database, e.g. "America/New_York".
headsignspecifies the direction in which to travel on this line, as it is marked on the vehicle or at the departure stop. This will often be the terminus station.headwayspecifies the expected number of seconds between departures from the same stop at this time. For example, with aheadwayvalue of 600, you would expect a ten minute wait if you should miss your bus.num_stopscontains the number of stops in this step, counting the arrival stop, but not the departure stop. For example, if your directions involve leaving from Stop A, passing through stops B and C, and arriving at stop D,num_stopswill return 3.linecontains information about the transit line used in this step, and may include the the following properties:namecontains the full name of this transit line. eg. "7 Avenue Express".short_namecontains the short name of this transit line. This will normally be a line number, such as "M7" or "355".colorcontains the color commonly used in signage for this transit line. The color will be specified as a hex string such as: #FF0033.agenciescontains an array ofTransitAgencyobjects that each provide information about the operator of the line, including the following properties:namecontains the name of the transit agency.urlcontains the URL for the transit agency.phonecontains the phone number of the transit agency.
You must display the names and URLs of the transit agencies servicing the trip results.
urlcontains the URL for this transit line as provided by the transit agency.iconcontains the URL for the icon associated with this line.text_colorcontains the color of text commonly used for signage of this line. The color will be specified as a hex string.vehiclecontains the type of vehicle used on this line. This may include the following properties:namecontains the name of the vehicle on this line. eg. "Subway."typecontains the type of vehicle that runs on this line. See the Vehicle Type documentation for a complete list of supported values.iconcontains the URL for an icon associated with this vehicle type.
Vehicle Type
The vehicle.type property may return any of the following
values:
| Value | Definition |
|---|---|
RAIL |
Rail. |
METRO_RAIL |
Light rail transit. |
SUBWAY |
Underground light rail. |
TRAM |
Above ground light rail. |
MONORAIL |
Monorail. |
HEAVY_RAIL |
Heavy rail. |
COMMUTER_TRAIN |
Commuter rail. |
HIGH_SPEED_TRAIN |
High speed train. |
BUS |
Bus. |
INTERCITY_BUS |
Intercity bus. |
TROLLEYBUS |
Trolleybus. |
SHARE_TAXI |
Share taxi is a kind of bus with the ability to drop off and pick up passengers anywhere on its route. |
FERRY |
Ferry. |
CABLE_CAR |
A vehicle that operates on a cable, usually on the ground. Aerial cable
cars may be of the type GONDOLA_LIFT. |
GONDOLA_LIFT |
An aerial cable car. |
FUNICULAR |
A vehicle that is pulled up a steep incline by a cable. A Funicular typically consists of two cars, with each car acting as a counterweight for the other. |
OTHER |
All other vehicles will return this type. |
The sensor Parameter
The Google Maps API previously required that you include the
sensor parameter to indicate whether your application used a
sensor to determine the user's location. This parameter is no longer
required.