Create map images from slippy map tiles.
Project description
Map Maker
mapmaker is a simple script to generate map images for “Slippy Tile” maps. Map tiles are downloaded from services such as OpenStreetMap and are combined into a single image.
Installation
Use the installation script:
$ python setup.py install
Or install using pip:
$ pip install mapmaker
Command Line Usage
Use mapmaker --help to show a detailed list of options.
Basic Usage
This will create a file map.png in the current directory. The map will cover the bounding box specified with two pairs of lat/lon coordinates:
$ mapmaker 47.44,10.95 47.37,11.13
One can also specify a center point and a radius:
$ mapmaker 63.0695,-151.0074 100km
If the coordinates start with a negative value, use -- to indicate the end of command line flags:
$ mapmaker -- -32.653197,-70.0112 100km
Coordinates can also be specified in DMS format:
$ mapmaker "63°4'10.2'' N, 151°0'26.64'' W" 4km
Use a single quote for minutes (') and two single quotes ('') for seconds. Note the quotes around the command line argument.
You can also specify the output file (default is map.png):
$ mapmaker 63.0695,-151.0074 100km denali.png
Additional Options
Specify the zoom level with the --zoom flag. The default is 8. Higher values mean more detail and result in larger map images.
$ mapmaker 63.0695,-151.0074 100km --zoom 12
Use --style to control the look of the map:
$ mapmaker 63.0695,-151.0074 100km --style human
To control the resulting image format, use --aspect:
$ mapmaker 45.83,6.88 100km --aspect 16:9
The aspect ratio is given in the format W:H (e.g. 4:3 or 19:9). The resulting map image will contain the given bounding box (or point w/ radius) and max be extended to North/South or East/West to match the aspect ratio. Note that the resolution of the image depends on the --zoom factor.
Decorations
Set a headline with --title, specify optional PLACEMENT, COLOR and BORDER followed by the title string. The title will be added to the Margin Area and will force a margin that is large enough to accommodate the title.
- PLACEMENT:
one of the cardinal directions e.g. NW, NNW, N, NNE, NE, ....
- BORDER:
a single integer value for the border width in in pixels.
- COLOR:
RGB(A) tuple as a comma separated string, e.g. “255,0,0”.
- BACKGROUND:
RGB(A) tuple as a comma separated string, e.g. “255,0,0”.
Colors can also be specified as hex values, e.g. #ff0000 or #ff000080 (with opacity).
$ mapmaker 45.83,6.88 100km --title My Map
$ mapmaker 45.83,6.88 100km --title NNW My Map
$ mapmaker 45.83,6.88 100km --title NNW 5 My Map
$ mapmaker 45.83,6.88 100km --title NNW 5 255,0,0 My Map
$ mapmaker 45.83,6.88 100km --title NNW 5 255,0,0 0,0,255 My Map
Use --comment to add a comment in small print. Arguments are the same as for --title:
$ mapmaker 45.83,6.88 100km --comment My Comment
$ mapmaker 45.83,6.88 100km --comment SE 200,200,200 My Comment
Use --margin and --background to apply a border around the map. Note that some decoration arguments will automatically add a margin area.
margin is given in pixels as a single value (all sides), a pair of two values (top/bottom and left/right) or as four separate values for top, right, bottom, left (clockwise).
$ mapmaker 45.83,6.88 100km --margin 50
$ mapmaker 45.83,6.88 100km --margin 20 40
$ mapmaker 45.83,6.88 100km --margin 10 15 20 15
The color of the margin area can be controlled with --background. background is given as a comma separated RGB(A) value:
$ mapmaker 45.83,6.88 100km --margin 10 --background 200,200,200
$ mapmaker 45.83,6.88 100km --margin 10 --background 200,200,200,128
The --frame argument adds a border around the map content, that is between the map and the (optional) margin area. frame has up to four optional parameters:
- WIDTH:
The width in pixels, e.g. “8”.
- COLOR:
The main color as an RGB(A) value, e.g. “0,0,0” (black).
- ALT_COLOR:
The secondary color as an RGB(A) value, e.g. “255,255,255” (white).
- STYLE:
The style, either “solid” or “coordinates”.
Arguments can be supplied in any order. ALT_COLOR is only needed for styles that feature alternating colors, if two RGB(A) values are specified, the second is considered the ALT_COLOR.
All arguments are optional and if --frame is specified without arguments, a default frame will be drawn.
Examples:
$ mapmaker 45.83,6.88 100km --frame
$ mapmaker 45.83,6.88 100km --frame 12
$ mapmaker 45.83,6.88 100km --frame 12 255,0,0
$ mapmaker 45.83,6.88 100km --frame 12 255,0,0 0,0,255 coordinates
$ mapmaker 45.83,6.88 100km --frame coordinates
Use --scale to show a scale bar on the map. Optional arguments for scale are:
- PLACEMENT:
Where to place the scale, must be one of the map areas (e.g “SW”).
- WIDTH:
The width of the scale bar in pixels (e.g. “2”).
- COLOR:
The color to use for the scale bar an label, e.g. “0,0,0”.
- LABEL:
The label style, either default or nolabel.
- UNDERLAY:
Draw a partly transparent box below the scale bar to improve its readability against the map content.
The label shows the size of the scale in meters or kilometers.
Examples:
$ mapmaker 45.83,6.88 100km --scale
$ mapmaker 45.83,6.88 100km --scale SE
$ mapmaker 45.83,6.88 100km --scale 1
$ mapmaker 45.83,6.88 100km --scale 120,120,120
$ mapmaker 45.83,6.88 100km --scale nolabel
$ mapmaker 45.83,6.88 100km --scale full
$ mapmaker 45.83,6.88 100km --scale SE 1 120,120,120 nolabel full
GeoJSON
The --geojson option can be used to draw GeoJSON objects onto the map.
The GeoJSON can contain additional attributes to control the color, line width, etc. The additional attributes can be part of a Geometry or part of the properties attribute of a parent Feature. Have a look hat the module documentation to see which special attributes are supported.
{
"type": "Feature",
"geometry": {
"type": "Point",
"coordinates": [12.594474, 55.691438]
},
"properties": {
"symbol": "square",
"color": [10, 147, 150],
"size": 12
}
}
You can also use any Geometry object directly:
{
"type": "Polygon",
"coordinates": [
[8.612316, 47.680632],
[8.612316, 47.676327],
[8.617423, 47.676327],
[8.617423, 47.680632]
]
"color": [60, 9, 108],
"fill": [60, 9, 108, 120]
}
The --geojson option supports a path to a JSON file or a JSON formatted string.
Create a Gallery
Use the --gallery flag to render a set of maps, one for each available style. In this case, you specify an output directory instead of a file (default is the current directory). This flag ignores the --style parameter.
Configuration
The configuration file is located at ~/.config/mapmaker/config.ini
Styles (Tile Servers)
You can specify additional map styles like this:
# ~/.config/mapmaker/config.ini
[service.osm]
osm = https://tile.openstreetmap.org/{z}/{x}/{y}.png
[service.opentopo]
subdomains = abc
topo = https://{s}.tile.opentopomap.org/{z}/{x}/{y}.png
Where osm or topo are the names of the style (as used in the --style flag) and the URL is the URL pattern for downloading tiles.
Section names can be chosen freely but have to start with service.. Each section may contain the following reserved entries:
[service.example]
tile_size = 512
api_key = my-secret-api-key
subdomains = abcdef
Any other entries are expected to be key/value pairs with URL patterns. If no tile_size is configured, the default size (256px) is used.
The URL pattern must contain three variables:
- z:
zoom level
- x:
X-coordinate of the tile
- y:
Y-coordinate of the tile
See for example https://wiki.openstreetmap.org/wiki/Tiles.
The URL may contain additional placeholders for an API Key (see below) and a subdomain:
topo = https://{s}.tile.opentopomap.org/{z}/{x}/{y}.png ^^^ atlas = https://tile.thunderforest.com/atlas/{z}/{x}/{y}.png?apikey={api} ^^^
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 mapmaker-1.6.1.tar.gz
.
File metadata
- Download URL: mapmaker-1.6.1.tar.gz
- Upload date:
- Size: 72.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.1.dev0+g94f810c.d20240510 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e12eb223ac80e30fd0d0912dec3c039bc85a02c8455876a2201687d872f939f6 |
|
MD5 | 57ea66fb51d50181a13d5d59828ccb75 |
|
BLAKE2b-256 | afe510a93d5a0b3b0839b84f5e5a5986f424bba8fb7a2ed1f178ee8511e16fa4 |
File details
Details for the file mapmaker-1.6.1-py3-none-any.whl
.
File metadata
- Download URL: mapmaker-1.6.1-py3-none-any.whl
- Upload date:
- Size: 52.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.1.dev0+g94f810c.d20240510 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d0956a34a2e6829e2bc62ed1a1d265d265ba7e2fb9f29a085d3c8733923158ab |
|
MD5 | 24889d8a045607b97499ad06383a6685 |
|
BLAKE2b-256 | 5af23fd33d9df79d50e298e05ae7d7080154118f84e3c58809f392c89becd31d |