Render a map for a given area to paper using landez and mapnik
Project description
Rendering paper maps from tiles using Landez and Mapnik
This program renders an area with given boundaries using tiles from either a mapbox MBTiles file, a tile server or locally rendered using mapnik. It is designed to work with hikingmap but it can be used standalone as well if desired.
Installation
Clone this repository and run the following command in the created directory.
python setup.py install
Usage
hm-render-landez [OPTION]... [gpxfiles]... bbox|center ...
Options:
Parameter | Description |
---|---|
--pagewidth |
Page width in cm |
--pageheight |
Page height in cm |
-b, --basename |
Base filename without extension |
-t |
Temp track file to render. This is used by hikingmap to draw the page boundaries of the overview map, the tracks will be saved as a temporary GPX file. |
-y |
Temp waypoints file to render. This is used by hikingmap to render the distance each kilometer or mile, the waypoints will be saved as a temporary GPX file. |
-v, --verbose |
Display extra information while processing. |
-h, --help |
Display help |
-d, --dpi |
Amount of detail to render in dots per inch, default 300 |
-S, --scale-factor |
Scale factor, default 1.0 |
--hikingmapstyle |
Hikingmap stylesheet file, contains the CartoCSS for the tracks and the waypoints. The default is hikingmapstyle.xml, see the repository for an example. |
-f, --format |
Output format. Consult the mapnik documentation for possible values, default png |
--mbtiles |
Input raster mbtiles file |
--mapnik-style |
Mapnik stylesheet file |
--wmts-url |
Remote URL to download tiles |
--wmts-subdomains |
URL subdomains |
--cachedir |
Local folder containing cached tiles, will be placed in the system temp directory if not specified |
--tilesize |
Tile size, default 256 |
--tileformat |
Tile image format, default image/png |
--tilescheme |
Tile scheme, default wmts |
gpxfiles |
The GPX track(s) to render. |
You should at least specify one tile source, read the section about tile source precedence for detailed information. After these parameters you are required to make a choice between bbox and center. In bbox mode the rendered area will be a defined bounding box and in center mode you can specify a center coordinate and a scale.
Options for bbox mode:
Parameter | Description |
---|---|
-o, --minlon |
Minimum longitude of the page |
-O, --maxlon |
Maximum longitude of the page |
-a, --minlat |
Minimum latitude of the page |
-A, --maxlat |
Maximum latitude of the page |
Note that mapnik will maintain the aspect ratio, the rendered area may not correspond exactly to the given boundary.
Options for center mode:
Parameter | Description |
---|---|
--lon |
Longitude of the center of the page |
--lat |
Latitude of the center of the page |
--scale |
Scale denominator, default 50000 |
Configuration file
Because most of the time you will want to use the same parameters, you can optionally override the defaults in a configuration file. hm-render-mapnik will search for a file hm-render-landez.config.xml in the current directory, if not found it will resort to ~/.hm-render-landez.config.xml
<?xml version="1.0" encoding="utf-8"?>
<hm-render-landez>
<tilesmanager>
<mbtiles_file>mbsource.mbtiles</mbtiles_file>
<mapnik_stylefile>mapnik_style.xml</mapnik_stylefile>
<wmts_url>https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png</wmts_url>
<wmts_subdomains>abc</wmts_subdomains>
<cache_dir>tilecache</cache_dir>
<tile_size>256</tile_size>
<tile_format>image/png</tile_format>
<tile_scheme>wmts</tile_scheme>
</tilesmanager>
<hikingmapstyle>hikingmap_style.xml</hikingmapstyle>
<outputformat>png</outputformat>
<dpi>300</dpi>
<scalefactor>1.0</scalefactor>
<fontdirs>
<fontdir>/usr/share/fonts/noto</fontdir>
<fontdir>/usr/share/fonts/noto-cjk</fontdir>
<fontdir>/usr/share/fonts/TTF</fontdir>
</fontdirs>
</hm-render-landez>
Options:
Tag | Description |
---|---|
mbtiles_file | Optional. An MBTiles file providing raster tiles. |
mapnik_stylefile | Optional. Mapnik stylesheet file. |
wmts_url | Optional. Remote URL to download tiles. |
wmts_subdomains | Optional. URL subdomains. |
cache_dir | Local folder containing cached tiles. |
tile_size | Tile size. |
tile_format | Tile image format. |
tile_scheme | Tile scheme, value can be tms or wmts. |
hikingmapstyle | Hikingmap stylesheet file, contains the CartoCSS for the tracks and the waypoints, see the repository for an example. |
outputformat | Output format. Consult the mapnik documentation for possible values. |
dpi | Amount of detail to render in dots per inch. This value is unrelated to the setting on your printer, a higher value will simply result in smaller icons, thinner roads and unreadable text. |
scalefactor | The scale factor to compensate for a higher dpi value. |
fontdirs | Optional. Can contain one or more fontdir subtags with additional font directories to be used by mapnik. |
Prerequisites
To run this script you should have a working installation of python 3, Landez and mapnik. Make sure you also have python-mapnik installed.
Tile sources
The tiles are cached in a local folder using the tile manager of Landez. Landez will add tiles to the cache when necessary, supporting a number of possible sources.
MBTiles
This is a file format from mapbox, they can be created using tools such as (but not limited to) mapbox mbutil or Maperitive. Please note that only raster MBTiles files are supported, vector MBTiles files require rendering before use.
Tile server
This is the easiest to set up, Landez will simply download tiles from a web source. Make sure you don't violate usage policies if you render too many maps at once or set the dpi value too high.
Local rendering with mapnik
Since mapnik is installed as a prerequisite of this project, it is included as a possible tile source. However the setup is rather difficult. Consult the documentation of hm-render-mapnik to get an idea.
WMS server
Although Landez supports WMS sources, it is not configurable here. WMS servers are generally replaced by WMTS servers, which use fewer resources on the server side.
Tile source precedence
Please note you should at least specify one tile source. Although it is possible to pass all tile sources together, Landez will use only one of them. The precedence is:
- MBTiles, pass the parameter
--mbtiles
if you want to use this. - Mapnik, pass the parameter
--mapnik-style
if you want to use this, but don't pass--mbtiles
. - Tile server, pass the parameters
--wmts-url
and--wmts-subdomains
, but don't pass--mbtiles
and--mapnik-style
.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file hm-render-landez-0.0.2.tar.gz
.
File metadata
- Download URL: hm-render-landez-0.0.2.tar.gz
- Upload date:
- Size: 9.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 75fe8d6abf7d0aadd05a195c6a143f03a77a2f67cae8a57ec7497e2e2ff30748 |
|
MD5 | 4ee2de4477d0465f197e87a38ac023f7 |
|
BLAKE2b-256 | 256829f0aee084b578ab95792e7cb4c7ecf076ff4f96dc46b78117ade3d43969 |
File details
Details for the file hm_render_landez-0.0.2-py3-none-any.whl
.
File metadata
- Download URL: hm_render_landez-0.0.2-py3-none-any.whl
- Upload date:
- Size: 21.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 85dcafaabb3eef1a603873b442efdde82f40a5038f4cb6b5b830985ea6bb66dc |
|
MD5 | 6a5c65c59bc9e6655e405343868ebaad |
|
BLAKE2b-256 | 32399753a21f211b937a1a7b4b9502a7e348a46957cfbc26661a2fbbdc779ff3 |