Génération d'un rendu pour une carte cyclable régionale
Ce tutoriel est en cours d'écriture donc inexploitable tel quel, mais n’hésitez pas à proposer des améliorations et simplifications si vous avez des connaissances
Axel de Dynamo Nancy (axel[arobase]broman[point]fr).
Sommaire
Préambule
L’intérêt de travailler avec OpenStreetMap est de donner la possibilité à ceux réutilisant la carte générée, de pouvoir améliorer et correctionner les données y figurantes. Il s'agit en effet d'une cartographie libre et participatif, similaire à ce qu'est Wikipédia pour l'encyclopédie. Aussi les données issues d'OSM sont sous licences libres, les seules limitations quant à leurs réutilisations hormis une paternité (Les contributeurs d'OpenStreetMap), est l'obligation de redistribuer ces données et éventuellement les modifications apportées sous cette même licence ou équivalente.
Les logiciels utilisés dans ce tutoriel sont sous licence libre, hors Maperitive qui n'a pas d’équivalence (il est tout de même gratuit et multi-plateforme). L’intérêt est là de donner la possibilité à tous de pouvoir reproduire le travail avec le minimum de contrainte.
Ce tutoriel nécessite un ordinateur relativement performant et une bonne capacité de stockage est conseillé. Il est adapté pour un système d'exploitation GNU/Linux Debian/Ubuntu. Si vous utilisez un autre système, ces logiciels existent pour Windows, MAC OSX et GNU/Linux, mais c'est à vous de vous adapter !
Le tutoriel permet de générer une carte sur une échelle régionale, mais il est tout à fait possible de créer un rendu pour une ville ou un pays ou bien encore d’autres thèmes. Les règles seront juste à ajuster en fonction de la quantité de données voulus, et de ce qui est recherché.
Méthodologie
osmctools
Ce logiciel permet de récupérer uniquement les données étant utiles pour la création du rendu sur mesure. Les fichiers originaux des régions faisant en général plusieurs gigaoctets de données, cette solution permet de travailler par la suite sur des données sensiblement moins importantes, et donc raccourcis les temps de traitements. À noter que le logiciel n'a pas d'interface graphique, tout s'effectue avec un terminal.
Installer le logiciel osmctools
- Disponible dans les dépôts
Télécharger la carte
- Chargez la carte de la région sur Geofabrik en format compressé osm.bz2, et décompresser
- http://download.geofabrik.de/europe/france.html
Si la région n'est pas disponible, deux solutions :
- Chargez chacune des anciennes régions constituantes la nouvelle
osmconvert lorraine.osm alsace.osm champagne.osm -o=grand_est.osm
- Il est conseillé de charger les régions au même moment afin d’éviter d'avoir des conflits lors de la fusion.
- Chargez la France et découpez selon les frontières de la région
osmconvert france-latest.osm -B=region.poly -o=region.osm
- Le fichier region.poly peut être généré à partir de JOSM avec une extension homonyme.
Générer fichiers avec données à charger
- Les règles sont à adapter selon ce qui est rechargé pour le rendu, quelques exemples basiques :
osmfilter region.osm --keep="service:bicycle:diy=yes" >ateliers.osm
osmfilter region.osm --keep= --keep-relations="route=bicycle" >veloroutes.osm
osmfilter region.osm --keep="place=city" --keep="place=town" >villes.osm
fusionner les fichiers précédemment générés
osmconvert ateliers.osm veloroutes.osm villes.osm -o=carte.osm
Nous travaillerons par la suite avec le fichier carte.osm.
Voici les règles que j'utilise avec osmctools (en cours de complétion).
- // nœuds (nodes)
- --keep-nodes="service:bicycle:diy=yes" // ateliers de réparations vélos "faites le vous même"
- --keep-nodes="place=city" // ville de plus de 100 000 habitants
- --keep-nodes="place=town" // ville de plus de 10 000 habitants
- // chemins (ways)
- --keep-ways="landuse=" // occupations des sols
- --keep-ways="natural=water" // lacs, étangs
- --keep-ways="waterway=" // cours d'eaux divers
- // relations
- --keep-relations="route=bicycle" // Véloroutes (EuroVelo, VXX, locaux)
- --keep-relations="admin_level=6" // Frontières des départements
- --keep-relations="natural=water" // lacs, étangs
- --keep-relations="waterway=" // cours d'eaux divers
- --keep-relations="landuse=" // occupations des sols
Il est possible d’intégrer toutes ces règles dans un unique fichier, ce qui évite la fusion
Créez un fichier nommé "regles", y copier le contenu ci-dessous
- -v veut dire verbose, c'est à dire bavard et donne des indications sur l'avancement de la requête
-v --keep-nodes= service:bicycle:diy=yes --keep-nodes= place=city --keep-nodes= place=town --keep-ways= landuse= --keep-ways= natural=water --keep= waterway= --keep-relations= route=bicycle --keep-relations= admin_level=6 --keep-relations= natural=water --keep-relations= waterway= --keep-relations= landuse=
Puis lancer cette commande
osmfilter region.osm --parameter-file=regles >carte.osm
Maperitive
Ce logiciel permet de générer un rendu à partir des données OpenStreetMap. Tant pour du format papier (ce qui nous intéresse principalement), que pour du format web sous forme de tuiles (ceci ne sera pas traité dans ce tutoriel car demande des connaissances en gestion serveur web). Le rendu peut être généré en format vectoriel (SVG), et bitmap (PNG).
Installer Maperitive
Installer et démarrer le logiciel Maperitive et décompresser le fichier.
- http://maperitive.net/
- Il nécessite la librairie Mono, disponible dans les dépôts.
- Démarrer avec le fichier Maperitive.exe
- Le rendu OSM Mapnik est visible par défaut, supprimer ou désactivez-le en bas à droite.
Charger les données dans Maperitive
- Un rendu classique s'affichera
- File -> Open Map Sources...
- Charger le fichier précédemment généré region.osm
Charger les règles
- qui n'existent pas encore !
Manipulations facultatifs
Script pour afficher les noms de départements
- Par défaut, Maperitive ne sait pas exploiter convenablement les relations OSM, il n'est pas possible d'afficher les noms des départements.
- Cependant, il est possible de contourner cette limitation via un scipt Python, en convertissant la relation en simple polygonne.
Pour ce faire créez un fichier Python :
convert_bundary_relation_polygone.py
Et y copier ceci :
from maperipy import * from maperipy.osm import * for layer in Map.layers: if layer.layer_type == "OsmLayer": osmWayList = layer.osm for relation in osmWayList.find_relations(lambda x : True): if relation.has_tag("boundary","administrative") and relation.has_tag("type"): osmWayList.relation(relation.id).set_tag("type","multipolygon")
Dans Mapertive, copiez ceci dans la barre de commandes, et validez :
run-python /chemin du fichier/convert_bundary_relation_polygone.py
Il ne reste plus qu'à recharger le rendu
- Faites Ctrl + R
Désactiver la collision
- Maperitive utilise par défaut un système d'anti collision de textes : s'ils se chevauchent certains d'entre eux ne sont pas affichés.
- Il existe deux solution:
- Utiliser la balise "placement-value" dans le fichier de règles de rendu, ce qui supprimera les textes selon la configuration indiqué. Lisez la documentation de Maperitive si vous choisissez cette solution.
- Tout afficher, puis les déplacer et/ou supprimer par la suite avec le logiciel Inkscape.
Pour cette seconde solution, il suffit de désactiver la fonctionnalité directement dans la barre de commandes de Maperitive :
set-setting name=map.rendering.detect-label-collision value=false
Maintenant, vous pouvez recharger le rendu (Ctrl + R).
truc à faire : introduire les courbes de niveaux + éventuellement ombrages relief
Documentations
- Le wiki OSM pour retrouver les balises (en français/anglais)
- Osmfilter (en anglais)
- Osmconvert (en anglais)
- Maperitive (en anglais)