Choisir les informations à renvoyer
Lorsque vous appelez une méthode pour calculer une route ou une matrice de routage, vous devez spécifier les informations souhaitées en répertoriant les champs dans la réponse. Il n'existe pas de liste par défaut des champs renvoyés. Si vous omettez cette liste, les méthodes renvoient une erreur.
Vous spécifiez la liste de champs en créant un masque de champ de réponse. Vous transmettez ensuite le masque de champ de réponse à l'une des méthodes à l'aide du paramètre d'URL $fields
ou fields
, ou à l'aide de l'en-tête HTTP ou gRPC X-Goog-FieldMask
.
L'utilisation d'un masque de champ est une bonne pratique de conception pour s'assurer que vous ne demandez pas données inutiles, ce qui permet d'éviter le temps de traitement et les frais facturés.
Pour en savoir plus sur les paramètres d'URL, consultez la section Paramètres système.
Définir un masque de champ de réponse
Le masque de champ de réponse est une liste de chemins d'accès séparés par une virgule, où chaque path spécifie un champ unique dans le message de réponse. Le chemin commence à partir du message de réponse de niveau supérieur et utilise un un chemin d'accès au champ spécifié, séparé par un point.
Créez et spécifiez un chemin de champ comme suit :
- Recherchez les champs contenant les informations dont vous avez besoin dans l'API Routes. Pour en savoir plus, consultez Références de champ.
- Déterminez les chemins d'accès des champs dont vous avez besoin et créez les masques de champ correspondants: pour en savoir plus, consultez Déterminer le masque de champ à utiliser.
Combinez les masques de champ pour tous les champs dont vous avez besoin, en les séparant par une virgule. Par exemple, pour demander le
distanceMeters
pour la section de l'itinéraire ainsi que la durée de chaque étape de l'itinéraire, saisissez les deux informations, séparées par une virgule, sans espaces:routes.legs.distanceMeters,routes.legs.steps.duration
Envoyez le masque de champ avec votre requête API. Par exemple, dans une requête cURL, vous devez spécifier le masque de champ avec
-H
etX-Goog-FieldMask
:-H X-Goog-FieldMask: routes.legs.distanceMeters,routes.legs.steps.duration
Références de champ
Pour connaître les champs que vous pouvez demander dans une réponse à l'aide de masques de champ, consultez les références de l'API Routes indiquées dans la liste suivante. Spécifiez les champs en casse camel, comme indiqué dans la documentation de référence. Par exemple, routePreference
.
Ces références incluent les champs disponibles. Toutefois, vous devez vous reporter à la hiérarchie des champs pour déterminer le chemin d'accès complet du masque de champ. Pour savoir comment obtenir la hiérarchie des champs, consultez Déterminer le masque de champ à utiliser.
- Calculer le masque de champ de route
- Calculer les masques de champ de la matrice de routage
- REST : spécifie les champs du corps de la réponse à renvoyer.
- gRPC : spécifie les champs de l'objet RouteMatrixElement dans la réponse à renvoyer.
Déterminer les masques de champ à utiliser
Voici comment déterminer les champs que vous souhaitez utiliser et créer les masques de champ correspondants :
- Demandez tous les champs à l'aide d'un masque de champ de
*
. - Examinez la hiérarchie des champs dans la réponse à la question les champs de votre choix.
Créez vos masques de champ en utilisant la hiérarchie des champs présentée à l'étape précédente, en utilisant le format suivant:
topLevelField[.secondLevelField][.thirdLevelField][...]
Par exemple, pour cette réponse partielle d'un parcours :
"routes": [ { "legs": [ { "steps": [ {"distanceMeters": 119}, {"distanceMeters": 41} ] } ], "distanceMeters": 160 } ]
Si vous ne souhaitez renvoyer que le champ distanceMeters
pour l'étape du parcours, c'est-à-dire le dernier distanceMeters
de l'exemple précédent, votre masque de champ est le suivant :
routes.legs.distanceMeters
Si vous souhaitez plutôt renvoyer le champ distanceMeters
pour chaque étape de l'itinéraire, c'est-à-dire le distanceMeters
sous steps
dans l'exemple précédent, votre masque de champ est le suivant :
routes.legs.steps.distanceMeters
Si vous souhaitez renvoyer les deux, avec le résultat ci-dessus, votre masque de champ se présente comme suit:
routes.legs.distanceMeters,routes.legs.steps.distanceMeters
Exemples de chemins de masque de champ
Cette section contient d'autres exemples sur la manière de spécifier un chemin d'accès de champ dans le cadre d'un masque de champ de réponse dans les appels REST et gRPC.
Appel REST vers computeRoutes
Dans le premier exemple, vous utilisez un appel REST pour
Méthode computeRoutes
pour calculer
un itinéraire. Dans cet exemple, dans l'en-tête, vous spécifiez des masques de champ pour renvoyer les champs distanceMeters
et duration
de l'itinéraire dans la réponse. N'oubliez pas d'ajouter le préfixe routes
au nom du champ.
X-Goog-FieldMask: routes.distanceMeters,routes.duration
Appel REST à computeRouteMatrix
Pour l'API REST computeRouteMatrix
utilisée pour calculer une matrice de routage, dans l'en-tête, spécifier pour renvoyer
originIndex
, destinationIndex
et duration
pour chaque combinaison d'origines
et destination:
X-Goog-FieldMask: originIndex,destinationIndex,duration
Appel gRPC
Pour gRPC, définissez une variable contenant le masque de champ de réponse. Vous pouvez ensuite transmettre cette variable à la requête.
const ( fieldMask = "routes.distanceMeters,routes.duration,routes.polyline.encodedPolyline" )
Remarques concernant les chemins d'accès des champs
N'incluez que les champs dont vous avez besoin dans la réponse pour renvoyer uniquement les champs dont vous avez besoin :
- Réduit les temps de traitement, ce qui permet de renvoyer vos résultats avec une latence plus faible.
- Assure des performances de latence stables. Si vous sélectionnez tous les champs ou tous les champs au niveau supérieur, vous risquez de constater une dégradation des performances lorsque de nouveaux champs sont ajoutés et automatiquement inclus dans votre réponse.
- Résulte en une taille de réponse plus petite, ce qui se traduit par un débit réseau plus élevé.
- Elle vous assure de ne pas demander de données inutiles, ce qui permet d'éviter des délais de traitement et des frais facturés inutiles.
Pour en savoir plus sur la création d'un masque de champ, consultez field_mask.proto.
Demander un jeton de routage
Pour demander à l'API Routes de renvoyer des jetons de parcours pour les parcours générés, procédez comme suit :
- Définissez les paramètres suivants, qui sont obligatoires pour renvoyer un jeton de parcours :
- Définissez
travelMode
surDRIVE
. - Définissez
routingPreference
surTRAFFIC_AWARE
ouTRAFFIC_AWARE_OPTIMAL
.
- Définissez
- Vérifiez qu'aucun de vos points de cheminement de route n'est un point de cheminement
via
. - Spécifiez le masque de champ
routes.routeToken
pour renvoyer un jeton de route:X-Goog-FieldMask: routes.routeToken
Vous pouvez utiliser le jeton de route pour votre itinéraire planifié dans le SDK Navigation. Pour en savoir plus, consultez Planifier un itinéraire (Android) ou Planifier un itinéraire (iOS).
Exemple de jeton de route
Voici un exemple de corps de requête cURL pour un itinéraire à une seule origine et une seule destination, utilisant des masques de champ pour demander un jeton d'itinéraire, ainsi que la durée, la distance et la polyligne de l'itinéraire :
curl -X POST -d {"origin":{ "location": { "latLng":{ "latitude": -37.8167, "longitude": 144.9619 } } }, "destination":{ "location": { "latLng":{ "latitude":-37.8155, "longitude": 144.9663 } } }, "routingPreference":"TRAFFIC_AWARE", "travelMode":"DRIVE" } -H 'X-Goog-Api-Key: YOUR_API_KEY' \ -H X-Goog-FieldMask: routes.routeToken,routes.duration,routes.distanceMeters,routes.polyline.encodedPolyline 'https://routes.googleapis.com/directions/v2:computeRoutes'
Pour en savoir plus, consultez la documentation de référence de l'API Compute Routes.