This is a script for generating interactive maps from GPS tracking data and geo-tagged images (see an example here).
pip install tourmapper
If you get an installation error along the lines of
proj executable not found. Please set the PROJ_DIR variable. For more information see: https://pyproj4.github.io/pyproj/stable/installation.html
then there is an issue installing the pyproj
package via pip. Installation via conda-forge may help correct this (conda install -c conda-forge pyproj
), then re-attempt the original pip install tourmapper
. Alternatively, build pyproj from source.
The script wraps Folium / Leaflet, a very sophisticated library for producing interactive maps. Map generation is done using the tourmapper.make_map()
function using the following arguments. There is some customisation that is possible, but for full control you may want to use those libraries directly (or edit this script).
gps_dir
string path to directory containing.gpx
files, all of which will be loaded in ascending date order. Each file will be a separate trace on the map.
outpath
string path to save map as single.html
file, defaulttourmap.html
map_params
dict containing map-specific arguments passed tofolium.Map()
(see the Folium or Leaflet documentation)image_dir
string path to directory containing.jpeg/.jpg
images with GPS EXIF tags, all of which will added to the mapline_colours
string, or list of strings which will be cycled, of colours to use when plotting each.gpx
file. These can either be simple names egred
or hex colour code#3388ff
ride_text
list of strings, same length as number of.gpx
files, of text to insert on the marker at the end of each file's trace on the map. HTML formatting will be respected.remote_image_url
string URL stub for remote loading of images (see below section)image_width
default 500, popup size for landscape imagesimage_height
default 400, popup size for portrait images
An example with images and text descriptions can be found here.
Some useful arguments to customise the map (these must be wrapped up in the map_params
dict):
api_key
,style
,tiles
: customising the basemap. Many options require a paid subscription (see the demos here)attr
the text attribution shown in the bottom corner of the maplocation
(latitude, longitude) coordinates to center the mapzoom_start
initial zoom level between 1 and 20 (far -> near)
By default, images are embedded directly within the HTML file containing the map. This means the map and images are completely self-contained within that single file, which makes it very easy to share, but the file size will be large if there are lots of images. If the file is hosted online the load time could be slow.
The alternative to this is to add the images as remote objects. This keeps the file size down, because they are not embedded into HTML, but means you need somewhere to store the images remotely (a website, hosting service etc) from which they will be loaded on-demand. Remote images can be added using the remote_image_url
argument.
The image_dir
contains the images A.jpg
, B.jpg
and C.jpg
. To insert them as remote images instead of local, first place them on a remote host (for example, yourwebsite.com/assets/images
). Pass this URL as the remote_image_url
argument, and the images A,B,C will be inserted into the map with the following URLs: yourwebsite.com/assets/images/A.jpg
, yourwebsite.com/assets/images/B.jpg
etc.
Note that the resultant map cannot be viewed using Jupyter notebook (it must be viewed through a web browser for the associated JS to work).
If you encounter problems with this functionality, the place to start is by ensuring you can actually access the remote image URLs that have been generated. For example, can you access yourwebsite.com/assets/images/A.jpg
from a web browser?
Please feel free to provide any feedback or bug reports on this repo.