Here is the basic workflow to update styles:
- Edit the styles file you want, e.g.
Roads.mapcss
- Run the
tools/unix/generate_drules.sh
script - Test how your changes look in the app
- Commit your edits and files changed by the script
- Send a pull request!
Please prepend [styles]
to your commit message and add Developers Certificate of Origin to it.
Files changed by the script should be added as a separate [styles] Regenerated
commit.
Please check a list of current styling issues and "icons wanted" issues.
To work with styles first clone the OM repository.
To run some scripts additional libraries are needed:
optipng
protobuf 3.17.3 (3.18.0 doesn't work!)
Map styles are defined in text files located in data/styles/clear/include/
:
- Forests, rivers, buildings, etc.
Basemap.mapcss
- Their text labels
Basemap_label.mapcss
- Roads, bridges, foot and bicycle paths, etc.
Roads.mapcss
- Their text labels
Roads_label.mapcss
- Icons for POIs and other features
Icons.mapcss
- City-specific subway networks
Subways.mapcss
- Light (default) theme colors:
style-clear/colors.mapcss
- Dark/night theme colors:
style-night/colors.mapcss
There is a separate set of these style files for the navigation mode in data/styles/vehicle/
.
Icons are stored in data/styles/clear/style-clear/symbols/
and their dark/night counterparts are in data/styles/clear/style-night/symbols/
.
- Add an svg icon to
data/styles/clear/style-clear/symbols/
(and tostyle-night
too) preferably look for icons in collections OM uses already - Add icon rendering/visibility rules into
data/styles/clear/include/Icons.mapcss
and to "navigation style"data/styles/vehicle/include/Icons.mapcss
- Run
tools/unix/generate_symbols.sh
to add new icons into skin files - Run
tools/unix/generate_drules.sh
to generate drawing rules for the new icons
- Add it into
data/mapcss-mapping.csv
(or better replace existingdeprecated
line) to make OM import it from OSM - If necessary merge similar tags in via
data/replaced_tags.txt
- Add a new icon (see above)
- If a new POI should be OSM-addable/editable then add it to
data/editor.config
- Add new type translation into
data/strings/types_strings.txt
- Add search keywords into
data/categories.txt
- Run
tools/unix/generate_localizations.sh
to validate and distribute translations into iOS and Android - Add new or fix current classifier tests at
/generator/generator_tests/osm_type_tests.cpp
if you can - Ideally, test the changes locally by generating some small region map
- Relax and wait for the next maps update :)
Changing display zoom level for features (e.g. from z16- to z14-) might not take effect until map's geometry/scale index is rebuilt (or a whole map regenerated):
- Build the
generator_tool
binary - Put a map file, e.g.
Georgia.mwm
into thedata/
folder in the repo - Run
../omim-build-release/generator_tool --generate_index=true --output="Georgia"
- The index of
Georgia.mwm
will be updated in place
If e.g. area
style rules are added for a feature that didn't have them before, then the rules
won't take effect until map files are regenerated.
Map style files syntax is based on MapCSS/0.2, though the specification is not supported in full and there are OM-specific extensions to it.
The tools/unix/generate_drules.sh
script uses a customized version of Kothic
stylesheet processor to compile MapCSS files into binary drawing rules files data/drules_proto*.bin
.
The processor also produces text versions of these files (data/drules_proto*.txt
) to ease debugging.
The tools/unix/generate_symbols.sh
script assembles all icons into skin files in various resolutions (data/resources-*/symbols.png
and symbols.sdf
).
There is a Designer version of the QT desktop app, which facilitates development by rebuilding styles and symbols quickly. Though building of the Designer tool is limited to macOS at the moment.