Accueil / Blog / Métier / 2014 / Construire un MBTiles le long d'un itinéraire

Construire un MBTiles le long d'un itinéraire

Par Mathieu Leplatre publié 10/04/2014, édité le 12/11/2015
Avec Landez, la zone couverte d'un fichier MBTiles peut suivre une ligne!
Construire un MBTiles le long d'un itinéraire

Lorsque l'on crée un fichier MBTiles, avec Tilemill par exemple, la zone couverte est rectangulaire (bounding box).

Dans cet article, nous allons utiliser Landez pour construire un MBTiles dont la zone couverte suit un itinéraire de randonnée.

Initialement, Landez a été développé pour construire des fonds de carte à la demande, avec pour objectif de permettre à des touristes d'avoir un carnet de voyage disponible hors connexion. Il s'agissait donc de couvrir la zone autour de chaque escale.

Pour un itinéraire, nous pouvons procéder de la même façon ! Pour chaque point de l'itinéraire, nous allons ajouter une zone de couverture large pour les niveaux de zoom faibles, et réduite pour les niveaux de zoom élevés.

from landez import MBTilesBuilder

# Un rayon pour les zooms faibles, l'autre
# pour les zooms élevés.
RADIUS_LARGE = 0.01 # ~1 km
RADIUS_SMALL = 0.05  # ~500 m

# Niveaux de zooms pour le monde entier
GLOBAL_ZOOMS = range(8)
# Niveaux de zooms pour les rayons larges
LOW_ZOOMS = range(8, 13)
# Niveaux de zooms pour les rayons réduits
HIGH_ZOOMS = range(13, 17)

mbtiles = MBTilesBuilder()

# On couvre le monde entier aux zooms faibles
mbtiles.add_coverage(bbox=(-180, -90, 180, 90),
                     zoomlevels=GLOBAL_ZOOMS)

# Itère sur les coordonnées qui consistuent
# l'itinéraire
coords = Trek.geometry.coords

for (lng, lat) in coords:
    # Construit les emprises à partir des rayons
    large = (lng - RADIUS_LARGE, lat - RADIUS_LARGE,
             lng + RADIUS_LARGE, lat + RADIUS_LARGE)
    small = (lng - RADIUS_SMALL, lat - RADIUS_SMALL,
             lng + RADIUS_SMALL, lat + RADIUS_SMALL)

    # Ajoute ces emprises au MBTiles à construire
    mbtiles.add_coverage(bbox=large, zoomlevels=LOW_ZOOMS)
    mbtiles.add_coverage(bbox=small, zoomlevels=HIGH_ZOOMS)

# Télécharger et packager !
mbtiles.run()

Aussi simple que ça !

Nous allons mettre ce fonctionnement en place pour le développement de l'application mobile de Geotrek, qui permettra de consulter les itinéraires et les fonds en mode déconnecté.

ABONNEZ-VOUS À LA NEWSLETTER !
Voir aussi
Cartographier le manteau neigeux avec Python Cartographier le manteau neigeux avec Python 08/01/2019

En quelques lignes de code, nous vous proposons de cartographier le manteau neigeux. Nous ...

Cartographie Web 3D - possibilités techniques en logiciels libres 08/01/2019

Au début, les cartes sur le web étaient planes. Puis, avec de plus en plus de données (imagerie ...

Retour State of the Map France 2018 Retour State of the Map France 2018 23/07/2018

L'équipe de Makina attendait avec impatience l'événement de l'année, State Of The Map 2018 à ...

Calcul d'itinéraires piétons avec OSRM Calcul d'itinéraires piétons avec OSRM 02/02/2018

Cet article présente différentes techniques utilisées dans le cadre du projet MoodWalkR pour ...

MoodWalkR: behind the scenes MoodWalkR: behind the scenes 30/09/2013

Understanding how MoodWalkR computes pedestrian routes.