Google Distance Matrix API for Node.js
Easily get traveling distance and duration info between locations with Google Distance Matrix API
Installation
npm install google-distance
Usage
var distance = require('google-distance');
distance.get(
{
origin: 'San Francisco, CA',
destination: 'San Diego, CA'
},
function(err, data) {
if (err) {
return console.error(err);
}
console.log(data);
});
The above example outputs the following data
object:
{
index: null,
distance: '502 mi',
duration: '7 hours 48 mins',
origin: 'San Francisco, CA, USA',
destination: 'San Diego, CA, USA',
mode: 'driving',
units: 'imperial',
language: 'en',
avoid: null,
sensor: false
}
Additional Parameters
In addition to 'origin' and 'destination,' you may include these options to tailor your query:
{
index: null(default),
mode: driving(default) | walking | bicycling,
units: imperial(default) | metric,
language: en(default),
avoid: null(default) | highways | tolls,
sensor: false(default) | true
}
More Examples
This one uses more options:
var distance = require('google-distance');
distance.get(
{
origin: 'San Francisco, CA',
destination: 'Los Angeles, CA',
mode: 'bicycling',
units: 'metric'
},
function(err, data) {
if (err) {
return console.error(err);
}
console.log(data);
});
Outputs:
{
index: null,
distance: '800 km',
duration: '1 day 21 hours',
origin: 'San Francisco, CA, USA',
destination: 'Los Angeles, CA, USA',
mode: 'bicycling',
units: 'metric',
language: 'en',
avoid: null,
sensor: false
}
Let's use latitude and longitude and an index:
distance.get(
{
index: 1,
origin: '37.772886,-122.423771',
destination: '37.871601,-122.269104'
},
function(err, data) {
if (err) {
return console.error(err);
}
console.log(data);
});
Outputs:
{
index: 1,
distance: '13.6 mi',
duration: '20 mins',
origin: 'Octavia Boulevard, San Francisco, CA 94102, USA',
destination: '2066-2070 University Avenue, Berkeley, CA 94704, USA',
mode: 'driving',
units: 'imperial',
language: 'en',
avoid: null,
sensor: false
}