KML

Sélectionnez une plate-forme:Android iOS JavaScript

Cette page explique comment afficher des données géographiques au format KML en utilisant conjointement GMUKMLParser et GMUGeometryRenderer. KML est un format couramment utilisé pour le rendu de données géographiques telles que des points, des lignes et des polygones.

La capture d'écran suivante montre quelques exemples de données KML affichées sur une carte:

Une carte avec des données KML

Prérequis et remarques

GMUKMLParser fait partie de la bibliothèque d'utilitaires du SDK Maps pour iOS. Si vous n'avez pas encore configuré la bibliothèque, suivez le guide de configuration avant de poursuivre la lecture de cette page.

Pour obtenir l'exemple de code complet, consultez les exemples d'applications sur GitHub.

Rendu de données KML

Pour afficher des données KML sur une carte, créez un GMUKMLParser avec le chemin d'accès à une ressource KML (KML_Sample.kml dans cet exemple). Ensuite, créez un GMUGeometryRenderer en transmettant l'instance GMUKMLParser. Enfin, appelez GMUGeometryRenderer.render(). L'exemple de code suivant montre le rendu des données KML sur une carte:

Swift

import GoogleMapsUtils

class KML: NSObject {
  private var mapView: GMSMapView!

  func renderKml() {
    guard let path = Bundle.main.path(forResource: "KML_Sample", ofType: "kml") else {
      print("Invalid path")
      return
    }

    let url = URL(fileURLWithPath: path)

    let kmlParser = GMUKMLParser(url: url)
    kmlParser.parse()

    let renderer = GMUGeometryRenderer(
      map: mapView,
      geometries: kmlParser.placemarks,
      styles: kmlParser.styles
    )

    renderer.render()
  }
}
      

Objective-C

@import GoogleMapsUtils;

@implementation KML {
  GMSMapView *_mapView;
}

- (void)renderKml {
  NSString *path = [[NSBundle mainBundle] pathForResource:@"KML_Sample" ofType:@"kml"];
  NSURL *url = [NSURL fileURLWithPath:path];
  GMUKMLParser *parser = [[GMUKMLParser alloc] initWithURL:url];
  [parser parse];
  GMUGeometryRenderer *renderer = [[GMUGeometryRenderer alloc] initWithMap:_mapView
                                                                geometries:parser.placemarks
                                                                    styles:parser.styles];
  [renderer render];
}

@end