mirror of
https://github.com/maplibre/martin.git
synced 2024-12-20 21:31:49 +03:00
docs: better differentiation between image_id
and sprite_id
s (#1491)
made sure that the differences between image and sprite ids is clearer The rationale is that I got stuck here for a bit and got quite confused. After reading the sourcecode, this was much clear. I am a bit too explicite on purpose, feel free to (ask to) revert/reduce/rewrite as you see fit. Docs are never written alone ^^
This commit is contained in:
parent
cc690e11a4
commit
554ee0f0c7
@ -1,10 +1,11 @@
|
|||||||
## Sprite Sources
|
## Sprite Sources
|
||||||
|
|
||||||
Given a directory with SVG images, Martin will generate a sprite -- a JSON index and a PNG image, for both low and high
|
Given a directory with SVG images, Martin will generate a sprite -- a JSON index and a PNG image, for both low and highresolution displays. The SVG filenames without extension will be used as the sprites' image IDs (remember that one sprite and thus `sprite_id` contains multiple images).
|
||||||
resolution displays. The SVG filenames without extension will be used as the sprite image IDs. The images are searched
|
The images are searched recursively in the given directory, so subdirectory names will be used as prefixes for the image IDs.
|
||||||
recursively in the given directory, so subdirectory names will be used as prefixes for the image IDs,
|
For example `icons/bicycle.svg` will be available as `icons/bicycle` sprite image.
|
||||||
e.g. `icons/bicycle.svg` will be available as `icons/bicycle` sprite image. The sprite generation is not yet cached, and
|
|
||||||
may require external reverse proxy or CDN for faster operation.
|
The sprite generation is not yet cached, and may require external reverse proxy or CDN for faster operation.
|
||||||
|
If you would like to improve this, please drop us a pull request.
|
||||||
|
|
||||||
### API
|
### API
|
||||||
|
|
||||||
@ -12,6 +13,8 @@ Martin uses [MapLibre sprites API](https://maplibre.org/maplibre-style-spec/spri
|
|||||||
several endpoints. The sprite image and index are generated on the fly, so if the sprite directory is updated, the
|
several endpoints. The sprite image and index are generated on the fly, so if the sprite directory is updated, the
|
||||||
changes will be reflected immediately.
|
changes will be reflected immediately.
|
||||||
|
|
||||||
|
You can use the `/catalog` api to see all the `<sprite_id>`s with their contained sprites.
|
||||||
|
|
||||||
##### Sprite PNG
|
##### Sprite PNG
|
||||||
|
|
||||||
![sprite](sources-sprites.png)
|
![sprite](sources-sprites.png)
|
||||||
@ -39,14 +42,14 @@ the PNG, there is a high DPI version available at `/sprite/<sprite_id>@2x.json`.
|
|||||||
|
|
||||||
#### Combining Multiple Sprites
|
#### Combining Multiple Sprites
|
||||||
|
|
||||||
Multiple sprite_id values can be combined into one sprite with the same pattern as for tile
|
Multiple `sprite_id` values can be combined into one sprite with the same pattern as for tile
|
||||||
joining: `/sprite/<sprite_id1>,<sprite_id2>,...,<sprite_idN>`. No ID renaming is done, so identical sprite names will
|
joining: `/sprite/<sprite_id1>,<sprite_id2>,...,<sprite_idN>`. No ID renaming is done, so identical sprite names will
|
||||||
override one another.
|
override one another.
|
||||||
|
|
||||||
### Configuring from CLI
|
### Configuring from CLI
|
||||||
|
|
||||||
A sprite directory can be configured from the CLI with the `--sprite` flag. The flag can be used multiple times to
|
A sprite directory can be configured from the CLI with the `--sprite` flag. The flag can be used multiple times to
|
||||||
configure multiple sprite directories. The name of the sprite will be the name of the directory -- in the example below,
|
configure multiple sprite directories. The `sprite_id` of the sprite will be the name of the directory -- in the example below,
|
||||||
the sprites will be available at `/sprite/sprite_a` and `/sprite/sprite_b`. Use `--save-config` to save the
|
the sprites will be available at `/sprite/sprite_a` and `/sprite/sprite_b`. Use `--save-config` to save the
|
||||||
configuration to the config file.
|
configuration to the config file.
|
||||||
|
|
||||||
@ -63,9 +66,11 @@ how [MBTiles and PMTiles](config-file.md) are configured.
|
|||||||
# Sprite configuration
|
# Sprite configuration
|
||||||
sprites:
|
sprites:
|
||||||
paths:
|
paths:
|
||||||
# all SVG files in this dir will be published as a "my_images" sprite source
|
# all SVG files in this directory will be published under the sprite_id "my_images"
|
||||||
- /path/to/my_images
|
- /path/to/my_images
|
||||||
sources:
|
sources:
|
||||||
# SVG images in this directory will be published as a "my_sprites" sprite source
|
# SVG images in this directory will be published under the sprite_id "my_sprites"
|
||||||
my_sprites: /path/to/some_dir
|
my_sprites: /path/to/some_dir
|
||||||
```
|
```
|
||||||
|
|
||||||
|
The sprites are now avaliable at `/sprite/my_images,some_dir.png`/ ...
|
||||||
|
Loading…
Reference in New Issue
Block a user