Un ID de carte est un identifiant unique qui représente les styles et les paramètres de configuration de Google Maps stockés dans Google Cloud. Vous utilisez des ID de carte pour activer des fonctionnalités, ou pour gérer ou styliser des cartes sur vos sites Web et dans vos applications. Vous pouvez créer des ID de carte pour chaque plate-forme dont vous avez besoin (JavaScript, Android, iOS ou cartes statiques) dans votre projet de console Google Cloud, sur la page Gestion des cartes.
Ce que vous pouvez faire avec les ID de carte
Utilisez des ID de carte pour activer les éléments géographiques et le style. Voici quelques exemples d'utilisation des ID de carte. Pour obtenir la liste complète, consultez la section Fonctionnalités qui utilisent des ID de carte:
Styles de cartes basés dans le cloud: associez un ID de carte à un style de carte pour styliser, personnaliser et gérer vos cartes à l'aide de la console Google Cloud. Disponible sur toutes les plates-formes : JavaScript, Android, iOS et API Maps Static.
Cartes vectorielles: utilisez un ID de carte pour utiliser une carte composée de tuiles vectorielles dessinées au moment du chargement côté client à l'aide de WebGL. Disponible en JavaScript.
Repères avancés: utilisez un ID de carte pour activer les repères avancés. Disponible sur JavaScript, Android et iOS.
Exemple de style de carte basé dans le cloud
Pour utiliser les styles de cartes basés dans le cloud pour styliser les cartes sur votre site Web et vos applications Android, procédez comme suit:
Créez des ID de carte pour chaque plate-forme que vous utilisez. Par exemple, créez un code JavaScript et un ID de carte Android. Pour en savoir plus, consultez Créer des ID de carte.
Configurez un style de carte dans la console Google Cloud. Pour en savoir plus, consultez la section Styles de cartes basés dans le cloud.
Associez vos deux ID de carte au style de carte dans la console Google Cloud. Pour en savoir plus, consultez Associer des ID de carte à votre style.
Faites référence à l'ID de la carte dans le code JavaScript de votre site Web et dans le code de votre application Android. Pour en savoir plus, consultez Ajouter un ID de carte à votre application.
Le style de carte associé à vos ID de carte s'affiche ensuite sur votre site Web et dans votre application Android. Vous pouvez modifier votre style de carte dans la console Cloud. Les modifications s'affichent automatiquement dans les deux emplacements, sans que vos clients aient besoin de mettre à jour l'application.
Fonctionnalités qui utilisent des ID de carte
Le tableau suivant présente les fonctionnalités et les API Google Maps Platform qui utilisent des ID de carte:
Fonctionnalité ou API | Utilise des ID de carte pour atteindre ces objectifs |
---|---|
Repères avancés | Activez les repères avancés. Vous n'avez pas besoin de créer d'ID de carte. Vous pouvez utiliser l'ID de carte de démonstration "DEMO_MAP_ID". |
Style basé sur les données pour les limites | Associez l'ID de carte à un ensemble de limites et de styles pour styliser la carte en fonction des limites. |
Style basé sur les données pour les ensembles de données | Associez l'ID de carte à un ensemble de données et à un style pour styliser la carte en fonction de l'ensemble de données. |
Flutter | Appliquez un style aux cartes Google utilisées dans vos applications Flutter. |
API Maps Embed | Spécifiez et stylisez la carte à intégrer sur une page Web. |
API Maps JavaScript | Appliquez un style à la carte à afficher sur une page Web. |
SDK Maps pour Android | Appliquez un style à la carte à afficher dans une application Android.1 |
SDK Maps pour iOS | Personnalisez la carte à afficher dans une application iOS.1 |
API Maps Static | Spécifiez et stylisez la carte à afficher en tant qu'image statique. |
Solutions de mobilité | Utilisez l'API Maps JavaScript et les SDK pour Android et iOS pour styliser les cartes dans les solutions de mobilité1. |
WebGL (cartes vectorielles) | Activez les fonctionnalités WebGL à l'aide d'un ID de carte vectorielle JavaScript. |
1 L'utilisation d'un ID de carte dans le SDK Maps pour Android ou dans le SDK Maps pour iOS déclenche un chargement de carte facturé en fonction du SKU Dynamic Maps.
Créer et utiliser des ID de carte
Un ID de carte est un identifiant unique qui représente une seule instance d'une carte Google. Vous créez des ID de carte et modifiez le style de carte associé à un ID de carte dans la console Cloud.
Autorisations requises
Pour créer ou gérer des ID de carte dans votre projet, vous devez utiliser un principal disposant des autorisations appropriées au niveau du rôle, Éditeur ou Propriétaire, sur la page IAM de la console Cloud pour le projet. Pour en savoir plus, consultez la page Documentation de référence sur les rôles IAM de base et prédéfinis.
Créer des ID de carte
Vous pouvez créer des ID de carte et mettre à jour un style associé à un ID de carte à tout moment dans Cloud Console.
Pour créer un ID de carte, procédez comme suit:
Connectez-vous à un projet Cloud Console et ouvrez-le avec les autorisations requises.
Dans Cloud Console, accédez à la page Gestion Maps.
Sélectionnez Créer un ID de carte.
Sur la page Créer un ID de carte, procédez comme suit:
- Dans le champ Name (Nom), attribuez un nom à l'ID de carte.
- Facultatif: Dans le champ Description, indiquez à quoi sert l'ID de carte.
- Dans Type de carte, sélectionnez la plate-forme sur laquelle vous prévoyez d'utiliser l'ID de carte. Si vous choisissez JavaScript, choisissez également un type de carte Raster (par défaut) ou Vecteur. Pour en savoir plus sur les cartes vectorielles, consultez la section Cartes vectorielles.
- Sélectionnez Enregistrer pour afficher votre nouvel ID de carte.
Associer un ID de carte à un style de carte
Dans ces instructions, nous partons du principe que votre projet contient au moins un style de carte. Si vous ne disposez d'aucun style de carte, consultez la section Styles de cartes basés dans le cloud et sélectionnez votre plate-forme pour savoir comment en créer un.
- Dans Cloud Console, accédez à la page Gestion Maps.
- Dans le tableau, sélectionnez un ID de carte existant.
- Sous Style de carte associé, sélectionnez un style de carte.
Sélectionnez Enregistrer.
Ajouter l'ID de carte à votre application
Android
Vous pouvez ajouter votre ID de carte via un élément <fragment>
du fichier de mise en page de l'activité, à l'aide de la classe MapView
ou de manière programmatique avec la classe GoogleMapOptions
.
Par exemple, supposons que vous ayez créé un ID de carte stocké sous la forme d'une valeur de chaîne nommée map_id
dans res/values/strings.xml
:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="map_id">MAP_ID</string>
</resources>
Pour les cartes ajoutées via un élément <fragment>
dans le fichier de mise en page de l'activité, tous les fragments de carte censés être associés au style personnalisé doivent spécifier l'ID de carte dans l'attribut map:mapId
:
<fragment xmlns:map="http://schemas.android.com/apk/res-auto"
map:name="com.google.android.gms.maps.SupportMapFragment"
…
map:mapId="@string/map_id" />
Vous pouvez également utiliser l'attribut map:mapId
de la classe MapView
pour spécifier un ID de carte :
<com.google.android.gms.maps.MapView
xmlns:android="http://schemas.android.com/apk/res/android"
....
map:mapId="@string/map_id" />
Pour spécifier un ID de carte de manière programmatique, transmettez-le à une instance MapFragment
à l'aide de la classe GoogleMapOptions
:
Java
MapFragment mapFragment = MapFragment.newInstance(
new GoogleMapOptions()
.mapId(getResources().getString(R.string.map_id)));
Kotlin
val mapFragment = MapFragment.newInstance(
GoogleMapOptions()
.mapId(resources.getString(R.string.map_id))
)
Dans Android Studio, créez et exécutez votre application comme vous le faites d'habitude. Les styles personnalisés configurés à la première étape sont appliqués à toutes les cartes avec l'ID de carte spécifié.
iOS
Pour instancier une carte à l'aide d'un ID de carte, procédez comme suit:
- Créez un
GMSMapID
avec la chaîne d'ID de carte à partir de la console Cloud. - Créez un
GMSMapView
en spécifiant l'ID de carte que vous venez de créer.
Swift
let camera = GMSCameraPosition(latitude: 47.0169, longitude: -122.336471, zoom: 12)
let mapID = GMSMapID(identifier: "MAP_ID")
let mapView = GMSMapView(frame: .zero, mapID: mapID, camera: camera)
self.view = mapView
Objective-C
GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:47.0169
longitude:-122.336471
zoom:12];
GMSMapID *mapID = [GMSMapID mapIDWithIdentifier:@"MAP_ID"];
GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero mapID:mapID camera:camera];
self.view = mapView;
Si vous utilisez votre propre ID de carte, vous pouvez définir un nouveau style pour votre ID de carte dans la console Cloud à tout moment. Ce style sera automatiquement appliqué à votre vue de carte pour vous et les utilisateurs dans un délai d'environ six heures.
Si vous souhaitez voir les modifications immédiatement, vous pouvez fermer et redémarrer votre application en la quittant, en forçant la fermeture de l'application depuis la liste des applications récemment utilisées, puis en la rouvrant. La carte mise à jour s'affiche alors.
JavaScript
Pour créer une carte avec un ID de carte dans le code de votre application:
Si vous personnalisez déjà votre carte avec du code JSON intégré, supprimez la propriété
styles
de votre objetMapOptions
. Sinon, ignorez cette étape.Ajoutez un ID de carte à la carte à l'aide de la propriété
mapId
. Exemple :
map = new google.maps.Map(document.getElementById('map'), { center: {lat: -34.397, lng: 150.644}, zoom: 8, mapId: 'MAP_ID' });
Maps Static
Pour ajouter un ID de carte à une carte nouvelle ou existante qui utilise l'une de nos API de service Web, ajoutez le paramètre d'URL map_id
et définissez-le sur votre ID de carte. Cet exemple montre comment ajouter un ID de carte à une carte à l'aide de l'API Maps Static.
<img src="https://maps.googleapis.com/maps/api/staticmap?center=Brooklyn+Bridge,New+York,NY&zoom=13&size=600x300&maptype=roadmap&markers=color:blue%7Clabel:S%7C40.702147,-74.015794&markers=color:green%7Clabel:G%7C40.711614,-74.012318&markers=color:red%7Clabel:C%7C40.718217,-73.998284&key=YOUR_API_KEY&map_id=MAP_ID&signature=YOUR_SIGNATURE" />