Génération d'un rendu pour une carte cyclable régionale

De Wiklou, le Wiki du Biclou
Révision datée du 24 janvier 2018 à 15:09 par Jeanne à vélo (discussion | contributions) (petite retouche)
Aller à : navigation, rechercher

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).

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, il n'y a donc aucune limitation quant à leurs réutilisations hormis une paternité (Les contributeurs d'OpenStreetMap).

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