This is one of the side projects that I develop and add new features from time to time.
Basically, It's a small single page website that can display the latest traffic information based on an origin location to multiple different locations. It uses Google Distance Matrix API to query the latest ETA from Google Maps. You need a valid GoogleMaps API key to query.
- Download the latest release and unzip. You may use the command below or do it manually.
curl -s https://api.github.com/repos/alatas/google-traffic-screen/releases/latest | grep "browser_download_url.*docker.zip" | head -1 | cut -d : -f 2,3 | cut -d '"' -f 2 | xargs curl -L -o release.zip ; unzip release.zip ; rm release.zip
-
Edit settings.yml and fill your google maps api key to the file. (Optional) Edit locations.yml file
-
Download and run the Docker container
docker-compose up
- Browse http://localhost:8901/
- Install the prerequisities (with pip)
pip install -U googlemaps pyyaml
- Download the latest release and unzip. You may use the command below or do it manually.
curl -s https://api.github.com/repos/alatas/google-traffic-screen/releases/latest | grep "browser_download_url.*[^docker].zip" | head -1 | cut -d : -f 2,3 | cut -d '"' -f 2 | xargs curl -L -o release.zip ; unzip release.zip ; rm release.zip
-
Edit settings.yml and fill your google maps api key to the file. (Optional) Edit locations.yml file
-
Run the script
python trafficscreen.py
- Browse http://localhost:8901/
Google Distance Matrix API has some customization options for calculation ETA value. Additionally, the script has schedule options to consume your API quota efficiently.
Tag | Example | Description |
---|---|---|
origin | ||
name | Grand Central Terminal | The name of the origin, that shown on the top of the display. |
address | 89 E 42nd St, New York, NY | The address of the origin. It is a significant information for the calculation. |
api_params | ||
api_key | You have to create a Google Cloud account and get a Maps API key. (for more information see below) | |
mode | driving | For the calculation of distances, you may specify the transportation mode. The following travel modes are supported: driving indicates distance calculation using the road network. walking requests distance calculation for walking via pedestrian paths & sidewalks (where available). bicycling requests distance calculation for bicycling via bicycle paths & preferred streets (where available). transit requests distance calculation via public transit routes (where available) |
language | en | The language in which to return results. You refer Google Maps API Documentation for the list of available languages |
units | imperial | Specifies the unit system to use when expressing distance as text. metric returns distances in kilometers and meters. imperial returns distances in miles and feet |
traffic_model | best_guess | Specifies the assumptions to use when calculating time in traffic. best_guess indicates that the returned ETA should be the best estimate of travel time given what is known about both historical traffic conditions and live traffic. pessimistic indicates that the returned ETA should be longer than the actual travel time on most days, though occasional days with particularly bad traffic conditions may exceed this value. optimistic indicates that the returned ETA should be shorter than the actual travel time on most days, though occasional days with particularly good traffic conditions may be faster than this value. |
schedule* | ||
onhour | 17 | This value indicates the start hour of the on-duty time in 24h format. |
onmin | 30 | This value indicates the start minute of the on-duty time. |
offhour | 20 | This value indicates end hour of the on-duty time in 24h format. |
offmin | 00 | This value indicates the end minute of the on-duty time. |
update_interval | 6 | The calculation interval in minutes. |
environment | ||
TZ | UTC | Time zone value of the system. You can use one of the possible time zone values listed by IANA. |
all_proxy | http://proxy:8080 | You can use this field to specify a proxy server to access the internet if you need or leave it blank. |
This is a single page application that uses Angular (v1.6.5), jquery (v3.2.1) and momentjs (v2.22.2). You may manually edit the index.html
file in www
folder to change the default theme. The CSS and JS elements are included in the index.html
file.
To use the Distance Matrix API, you must get an API key. The API key is used to track API requests associated with your project for quota, usage, and billing. According to new rules of Google Cloud, you must enable billing to get a Maps API key.
Follow these steps to get an API key and set up restrictions:
- Go to the Google Cloud Platform Console.
- Select the project for which you want to add an API key.
- Go to the Credentials page. (From the Navigation menu click APIs & Services > Credentials.)
- Click Create credentials > API key. The API key created dialog displays your newly created API key. Copy this key and paste into the appropriate field in settings.yml file. The following steps are optional.
- Click Restrict Key. (If you click Close, you can still set up restrictions later.)
- On the API key page, under Key restrictions, set the Application restrictions.
- Select IP addresses
- Add the IP addresses that you are using
- Click Save
For each billing account, for qualifying Google Maps Platform SKUs, a $200 USD Google Maps Platform credit is available each month. This means that you can use $200 worth Maps APIs for free each month. If you don't want to pay extra, you have to arrange your API usage to this limitation.
On the current pricing of the API, It's 0.01 USD per each item queried. Your monthly free quota, $200 equals to 20.000 items that should be queried per month for free. You have to arrange schedule settings to keep usage in this limit.
The formula is very simple as follows:
And also, you can set a quota to API to keep its in limits in Google Cloud Console.
Default schedule is every day 5:30 PM to 8:00 PM and the default interval is 6 minutes.
There are 2.5 hours (150 minutes) between 5:30PM to 8:00PM, this equals 150min / 6min interval = 25 data query per day.
There are 26 locations in default locations.yml file. That means 26 locations x 25 data query = 650 items are queried per day. 650 x 30 day = 19.500 items queried per month. Default values is barely in the limits.
There are 15 locations to query and the schedule is 8:00 AM to 8:00 PM every day.
We can calculate the maximum interval for keeping the usage in free limits.