Le schéma JSON pour la personnalisation de cartes dans le cloud vous permet d'utiliser JSON pour personnaliser les cartes comme vous le feriez avec l'interface de l'éditeur de style. Ce document décrit le schéma JSON et explique comment créer des déclarations de style JSON.
Pour savoir comment modifier un style de carte à l'aide de JSON dans l'éditeur de style, ou comment importer et exporter un style de carte, consultez Utiliser JSON avec les styles de cartes basés dans le cloud.
Consulter un exemple de déclaration de style JSON
La déclaration de style JSON suivante définit une couleur d'arrière-plan, puis définit des styles pour les points d'intérêt, les parcs et les éléments aquatiques, et masque les libellés des lieux de restauration.
{
"variant": "light",
"styles": [
{
"id": "natural.land",
"geometry": {
"fillColor": "#f7e3f7"
}
},
{
"id": "natural.water",
"geometry": {
"fillColor": "#d4b2ff"
},
"label": {
"textFillColor": "#3d2163",
"textStrokeColor": "#f0e1ff"
}
},
{
"id": "pointOfInterest",
"label": {
"pinFillColor": "#e0349a",
"textFillColor": "#a11e6e",
"textStrokeColor": "#ffd9f0"
}
},
{
"id": "pointOfInterest.emergency.hospital",
"geometry": {
"fillColor": "#ffe3e3"
}
},
{
"id": "pointOfInterest.foodAndDrink",
"label": {
"visible": false
}
},
{
"id": "pointOfInterest.recreation.park",
"geometry": {
"fillColor": "#f9b9d2"
}
}
]
}
L'objet JSON
Une déclaration de style JSON se compose d'un objet de premier niveau et d'un tableau de règles de style.
- Paramètres de premier niveau (facultatif) : paramètres de style généraux tels que
backgroundColoretvariant. styles: tableau d'objets de règles de style, qui peuvent se composer des éléments suivants :id: élément cartographique à sélectionner pour cette modification de style (par exemple,pointOfInterest.recreation.park).geometry(facultatif) : éléments géométriques de l'élément cartographique et règles de style à appliquer (par exemple,fillColor).label(facultatif) : libellé textuel ou d'épingle de l'élément cartographique et règles de style à appliquer (par exemple,textStrokeColor).
Paramètres de premier niveau
Les propriétés du tableau suivant s'appliquent à l'ensemble du style de carte.
| Propriété | Type | Description | Exemple |
|---|---|---|---|
|
Chaîne | Personnalisez la couleur d'arrière-plan de l'application de carte à l'aide d'une chaîne hexadécimale #RRGGBB. Ce paramètre n'est pas compatible avec les modifications de l'opacité. | "#002211" |
|
"light"|"dark" | Spécifiez le mode clair ou sombre. Si aucune valeur n'est spécifiée, la valeur par défaut est "light". | "light" |
|
booléen | Pour activer le mode monochrome, utilisez true pour afficher une version grise de la carte. |
|
Objets de règle de style
Cette section décrit les propriétés qui définissent les objets de règle de style dans le tableau styles pour personnaliser les éléments cartographiques. Chaque objet de règle de style doit se composer des éléments suivants :
- Propriété
id. - Élément
geometryoulabelavec les propriétés de style associées définies.
id (fonctionnalité de cartographie)
La propriété id spécifie l'élément de carte à styliser. Les noms de propriétés sont des versions en casse mixte des noms de caractéristiques de la carte dans l'éditeur de style.
Les éléments cartographiques forment une arborescence de catégories. Si vous spécifiez un type d'élément parent, comme pointOfInterest, les styles que vous spécifiez pour le parent s'appliquent à tous ses enfants, comme pointOfInterest.retail et pointOfInterest.lodging.
Pour en savoir plus, consultez Hiérarchie des éléments cartographiques.
Liste des propriétés id disponibles
Voici les propriétés id disponibles :
pointOfInterestpointOfInterest.emergencypointOfInterest.emergency.firepointOfInterest.emergency.hospitalpointOfInterest.emergency.pharmacypointOfInterest.emergency.policepointOfInterest.entertainmentpointOfInterest.entertainment.artspointOfInterest.entertainment.casinopointOfInterest.entertainment.cinemapointOfInterest.entertainment.historicpointOfInterest.entertainment.museumpointOfInterest.entertainment.themeParkpointOfInterest.entertainment.touristAttractionpointOfInterest.foodAndDrinkpointOfInterest.foodAndDrink.barpointOfInterest.foodAndDrink.cafepointOfInterest.foodAndDrink.restaurantpointOfInterest.foodAndDrink.winerypointOfInterest.landmarkpointOfInterest.lodgingpointOfInterest.recreationpointOfInterest.recreation.beachpointOfInterest.recreation.boatingpointOfInterest.recreation.fishingpointOfInterest.recreation.golfCoursepointOfInterest.recreation.hotSpringpointOfInterest.recreation.natureReservepointOfInterest.recreation.parkpointOfInterest.recreation.peakpointOfInterest.recreation.sportsComplexpointOfInterest.recreation.sportsFieldpointOfInterest.recreation.trailheadpointOfInterest.recreation.zoopointOfInterest.retailpointOfInterest.retail.grocerypointOfInterest.retail.shoppingpointOfInterest.servicepointOfInterest.service.atmpointOfInterest.service.bankpointOfInterest.service.carRentalpointOfInterest.service.evChargingpointOfInterest.service.gasStationpointOfInterest.service.parkingLotpointOfInterest.service.postOfficepointOfInterest.service.restStoppointOfInterest.service.restroompointOfInterest.transitpointOfInterest.transit.airportpointOfInterest.otherpointOfInterest.other.bridgepointOfInterest.other.cemeterypointOfInterest.other.governmentpointOfInterest.other.librarypointOfInterest.other.militarypointOfInterest.other.placeOfWorshippointOfInterest.other.schoolpointOfInterest.other.townSquarepoliticalpolitical.countryOrRegionpolitical.borderpolitical.reservationpolitical.stateOrProvincepolitical.citypolitical.sublocalitypolitical.neighborhoodpolitical.landParcelinfrastructureinfrastructure.buildinginfrastructure.building.commercialinfrastructure.businessCorridorinfrastructure.roadNetworkinfrastructure.roadNetwork.noTrafficinfrastructure.roadNetwork.noTraffic.pedestrianMallinfrastructure.roadNetwork.noTraffic.trailinfrastructure.roadNetwork.noTraffic.trail.pavedinfrastructure.roadNetwork.noTraffic.trail.unpavedinfrastructure.roadNetwork.parkingAisleinfrastructure.roadNetwork.rampinfrastructure.roadNetwork.roadinfrastructure.roadNetwork.road.arterialinfrastructure.roadNetwork.road.highwayinfrastructure.roadNetwork.road.localinfrastructure.roadNetwork.road.noOutletinfrastructure.roadNetwork.roadShieldinfrastructure.roadNetwork.roadSigninfrastructure.roadNetwork.roadDetailinfrastructure.roadNetwork.roadDetail.surfaceinfrastructure.roadNetwork.roadDetail.crosswalkinfrastructure.roadNetwork.roadDetail.sidewalkinfrastructure.roadNetwork.roadDetail.intersectioninfrastructure.railwayTrackinfrastructure.railwayTrack.commercialinfrastructure.railwayTrack.commuterinfrastructure.transitStationinfrastructure.transitStation.bicycleShareinfrastructure.transitStation.busStationinfrastructure.transitStation.ferryTerminalinfrastructure.transitStation.funicularStationinfrastructure.transitStation.gondolaStationinfrastructure.transitStation.monorailinfrastructure.transitStation.railStationinfrastructure.transitStation.railStation.subwayStationinfrastructure.transitStation.railStation.tramStationinfrastructure.urbanAreanaturalnatural.continentnatural.archipelagonatural.islandnatural.landnatural.land.landCovernatural.land.landCover.cropsnatural.land.landCover.dryCropsnatural.land.landCover.forestnatural.land.landCover.icenatural.land.landCover.sandnatural.land.landCover.shrubnatural.land.landCover.tundranatural.waternatural.water.oceannatural.water.lakenatural.water.rivernatural.water.othernatural.base
Éléments
Les éléments sont des subdivisions d'un élément de carte. Par exemple, une route se compose d'une ligne graphique (la geometry) sur la carte et du texte qui indique son nom (le label).
Les éléments suivants sont disponibles, mais notez qu'il est possible qu'un élément cartographique spécifique prenne en charge tous, certains ou aucun des éléments suivants :
geometry: sélectionne tous les éléments géométriques (par exemple, polygone ou polyligne) de l'élément cartographique spécifié.label: sélectionne tous les éléments de libellé (par exemple, le texte et l'épingle) de l'élément de carte spécifié.
Stylers
Les stylers vous permettent de définir vos règles de style pour chaque élément d'une entité cartographique.
Par exemple, pour une emprise au sol, vous pouvez styliser chaque élément comme suit :
Exemple de styles geometry pour un bâtiment |
Exemple de styles label pour un bâtiment |
|---|---|
| Indique si le polygone de l'emprise du bâtiment doit être masqué ou affiché sur la carte. | Indique s'il faut masquer ou afficher le libellé du bâtiment. |
| Couleur et opacité de remplissage du polygone. | Couleur et opacité du remplissage du texte |
| Couleur, opacité et largeur de la bordure | Couleur et opacité du trait du texte |
Cette section décrit les différentes options de style disponibles pour les éléments geometry et label.
geometry stylers
Le tableau suivant répertorie tous les stylers géométriques disponibles.
| Styler | Type | Description |
|---|---|---|
|
booléen | Pour masquer le polygone ou la polyligne d'un élément cartographique, définissez la valeur sur false. |
|
chaîne | Personnalisez la couleur du polygone ou de la polyligne avec une chaîne hexadécimale RVB. |
|
float | Personnalisez l'opacité du polygone ou de la polyligne, où 0 correspond à transparent et 1 à opaque. |
|
chaîne | Personnalisez la couleur du contour avec une chaîne hexadécimale RVB. |
|
float | Personnalisez l'opacité du contour, où 0 correspond à transparent et 1 à opaque. |
|
float | Personnalisez l'épaisseur du contour (de 0 à 8). |
Pour en savoir plus, consultez Polygones et polylignes.
label stylers
Le tableau suivant répertorie tous les stylers de libellés disponibles.
| Styler | Type | Description |
|---|---|---|
|
booléen | Pour masquer le libellé d'une entité cartographique, définissez la valeur sur false. |
|
chaîne | Personnalisez la couleur du libellé textuel avec une chaîne hexadécimale RVB. |
|
float | Personnalisez l'opacité du libellé de texte, où 0 correspond à transparent et 1 à opaque. |
|
chaîne | Personnalisez la couleur du contour avec une chaîne hexadécimale RVB. |
|
float | Personnalisez l'opacité du contour, où 0 correspond à transparent et 1 à opaque. |
|
float | Personnalisez l'épaisseur du contour (de 0 à 8). |
|
chaîne | Personnalisez la couleur du repère avec une chaîne hexadécimale RVB. |
Pour en savoir plus, consultez Icônes et libellés de texte.
Keyzooms
Vous pouvez définir un style unique pour une caractéristique pour tous les niveaux de zoom ou spécifier différents styles pour différents niveaux de zoom. Si vous ne fournissez qu'un seul style, il sera utilisé pour tous les niveaux de zoom clés à partir de z0. Si vous fournissez des styles pour différents niveaux de zoom, le style s'appliquera à partir de ce niveau de zoom jusqu'au prochain que vous avez défini.
Pour définir un niveau de zoom clé pour un style, dans la propriété de style, définissez le niveau de zoom clé de z0 à z22, puis la personnalisation du style.
Dans l'exemple suivant, la couleur de l'eau est noire pour les niveaux de zoom clés 0 à 5, gris foncé pour les niveaux de zoom clés 6 à 11 et gris clair à partir du niveau de zoom clé 12.
{
"id": "natural.water",
"geometry": {
"fillColor": {
"z0": "#000000",
"z6": "#666666",
"z12": "#cccccc"
}
}
}
Pour en savoir plus, consultez Appliquer un style aux niveaux de zoom.
Limites
Vous pouvez utiliser JSON pour styliser presque tous les éléments de la console Google Cloud, à l'exception des fonctionnalités suivantes du menu Paramètres de la carte :
- Contrôler la densité des points d'intérêt
- Modifier le style des bâtiments
- Modifier le style des points de repère
Pour ces fonctionnalités, vous devez sélectionner votre préférence dans le menu Paramètres de la carte .