Make a image of OSM data of an area from 2 dates, showing what was changed.
You can either install the necessary dependencies on your computer or run the script via Docker (both via MyBinder or in a local container).
- On macOS: install Homebrew
- Install
pipx
- Install
openstreetmap-carto
- Install
osmium-tool
- Install Mapnik
- Install
python-mapnik
- Install
nik4
(used to generate an image with theopenstreetmap-carto
map style):pipx install nik4
- Install GraphicsMagick
- On macOS: replace built-in
coreutils
commands with the GNU ones:brew install coreutils export PATH="$HOMEBREW_PREFIX/opt/coreutils/libexec/gnubin:$PATH
- Clone this repo:
git clone --recurse-submodules https://github.com/amandasaurus/osm-mapping-party-before-after cd osm-mapping-party-before-after
If you do not want to install the whole pipeline yourself, you can run this setup in a Docker container that is ready-to-use and that can also run in the free-to-use open source cloud infrastructure of MyBinder.
If you want to use the MyBinder version, click here and wait a bit. This will launch the version online in a virtual machine and lets you interact with the code through a small Python notebook that will launch automatically and contains all necessary instructions.
The MyBinder version has two drawbacks: 1. You will have to upload the OSM history file (*.osh.pbf) into the container. Depending on the region of interest these can be quite large. 2. Creating the maps will take longer, as other external downloads will have to be downloaded on the fly. See this blog post for more details.
If you want to run the Docker image on your own computer, the necessary image is available in the GitHub Container registry under amandasaurus/osm-mapping-party-before-after
.
Alternatively, you can also build the container locally if you want to make changes to it/improve it: We start by cloning this repository:
git clone --recurse-submodules https://github.com/amandasaurus/osm-mapping-party-before-after
cd osm-mapping-party-before-after
git submodule init
git submodule update
Then we build the image that is specified in the Dockerfile
, picking a name for the image, e.g. before_after_builder
.
Depending on how you installed Docker, you might have to run sudo
for each docker
command.
docker build -t before_after_builder .
This step needs to be run only once, and it can take a few minutes as it will download and build all the dependencies needed.
Once the step is finished, you can launch the container like so:
./docker_run.sh before_after_builder /full/path/to/in-out-dir/
The command takes two parameters:
- the name of the container (e.g. as specified during the
docker build
step) - a full path to a directory you want to use for accessing and writing files to from the container (i.e. input and output files). Depending on how you installed/run Docker, this folder might need full read/write permissions for other users (e.g. run
chmod 777
).
The docker_run.sh
command will then launch the container itself, including the necessary postgres database and the notebook interface. It will also create two virtual docker volumes (named pgdata
and osm_data
). These volumes are used to store external data, i.e. the database contents and the openstreetmap-carto
external files, so that subsequent launches are faster than the initial one.
After running the ./docker_run.sh
command you will see a lot of text running by while the container sets itself up. At the end of this, you should see this:
To access the server, open this file in a browser:
file:///home/postgres/.local/share/jupyter/runtime/jpserver-1-open.html
Or copy and paste one of these URLs:
http://1ce38bef580f:8888/tree?token=asecrettokenwithlotsofcharacters
http://127.0.0.1:8888/tree?token=asecrettokenwithlotsofcharacters
Clicking on the http://127.0.0.1:8888/tree?…
link will open the notebook interface in your web-browser, where you can open the make-images.ipynb
notebook, which will have all the necessary instructions to get started.
If you have tile-building setup on your computer, you can run make.sh
without Docker, following these steps:
- Download an OSM history file (
.osh.pbf
) e.g. from Geofabrik's internal download server. You will need to log in with an OSM account. - Calculate the
BBOX
with BBoxFinder.com.- Draw a rectangle
- Copy the Box value
- Make sure coordinates are in
long/lat
format (can be changed in the bottom-right)
- Run the following command:
The
./make.sh OSM_HISTORY_FILE.osh.pbf BEFORE_TIME AFTER_TIME BBOX MIN_ZOOM MAX_ZOOM
BEFORE_TIME
&AFTER_TIME
are ISO 8601 timestamps.
Copyright © 2021, Affero GPL v3+ (see LICENCE). Project is osm-mapping-party-before-after
on GitHub