Skip to content

Script to download raster layers from WMTS services. The process downloads each geoserver tile, geolocates it, and creates a world file for each tile.

Notifications You must be signed in to change notification settings

GastonZalba/wmts-downloader

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

wmts-downloader

Script to download raster layers from WMTS services. The proccess downloads each geoserver tile (256x256), geolocates it, and creates a world file for each tile. These can then be merged, cropped (and maybe reprojected) using gdal, qgis, etc. Keep it in mind that if the target zoom level is to high, and/or the area of interest is big enough, each execution can trigger thousands or millions of requests to the server, so use this with caution. To avoid overloading the server and facilitate the process, the script can resume incompleted jobs and add some sleep time betweeen requests. Running it multiples times with the same parameters, it will continue from the last downloaded tile.

Installation

  • Create a local enviroment running python -m venv .venv (install virtualenv if you don't have it)
  • Load the local enviroment: .venv\Scripts\activate
  • Install using pip install -r requirements.txt

Instructions

  • Load local enviroment .venv\Scripts\activate
  • Run python wmts-downloader.py --help to show all available options and arguments
  • Run the script with something like this python wmts-downloader.py https://imagenes.ign.gob.ar/geoserver/cartas_mosaicos/gwc/service/wmts --layer cartas_50k --zoom 14 --limit 1000 --bbox -7092196.7637569485232234 -5039771.7783368593081832 -6263492.7329376600682735 -3889283.7355505060404539
  • You can use the limit and sleep arguments to avoid overloading the target server. You can later rerun the script to continue from the last downloaded tile.
  • Check the console for details and the /output folder (the default) for the tiles

Example to combine tiles

  • Check combine-ign.py file to see an example to combine, crop and reproject the tiles using a geojson shape as reference.

Limitations

  • The projection EPSG:3857 is currently the only one supported

Todo

  • Add EPSG:4326 support

About

Script to download raster layers from WMTS services. The process downloads each geoserver tile, geolocates it, and creates a world file for each tile.

Topics

Resources

Stars

Watchers

Forks

Languages