Questions fréquentes

Informations sur le produit

Réseau et connectivité

Données

Personnalisation de l'interface utilisateur

Routage

Simulateur

Workflows

Services de mobilité

Informations sur le produit

Votre application doit implémenter une boîte de dialogue avec la notification des conditions d'utilisation du SDK Navigation que chaque utilisateur doit accepter. Cette boîte de dialogue permet à l'utilisateur d'accepter les conditions d'utilisation. Un fichier texte des conditions est fourni avec le SDK Navigation. Utilisez la méthode NavigationApi.showTermsAndConditionsDialog pour afficher la boîte de dialogue contenant les conditions.
Toutes les langues prises en charge par Google Maps Mobile sont automatiquement disponibles pour le SDK Navigation. Un appareil dispose d'une langue système par défaut et une application ne peut pas modifier ce paramètre. Toutefois, l'application a accès à plus de 70 langues.

Oui. Une fois lancé, LocationListener continue de s'exécuter en arrière-plan. Votre application continue de caler la position sur la route et maintient la direction.

Oui. Lorsqu'une route est créée ou modifiée, RouteChangeListener fournit des polylignes.

Non, le SDK Navigation n'exige pas que Google Maps Mobile soit installé sur l'appareil.
Non, le SDK Navigation ne propose pas cette fonctionnalité pour le moment.
Oui. Le sens de circulation est disponible et affiché par défaut.
Quelles versions du JDK sont compatibles avec le SDK Navigation ?
Le SDK Navigation est compatible avec les versions LTS de Java SE qui sont activement prises en charge par Oracle. Ces versions sont répertoriées comme bénéficiant d'un service d'assistance de premier plan dans la feuille de route de l'assistance Oracle Java SE.

Réseau et connectivité

Comment le SDK Navigation gère-t-il une mauvaise connectivité réseau ?
Le SDK Navigation pré-met en cache l'itinéraire pour chaque trajet. Les informations pré-mises en cache incluent des informations de calcul d'itinéraire pour 15 à 20 minutes, ainsi que des itinéraires alternatifs au cas où l'utilisateur s'écarterait de l'itinéraire. Le SDK Navigation détermine approximativement la position à l'aide du GPS et des capteurs de l'appareil.
Comment le SDK Navigation gère-t-il les signaux GPS de mauvaise qualité ou perdus ?

Une fois la navigation lancée et que le SDK de navigation a reçu un signal GPS au moins une fois, le message "Recherche du GPS…" s'affiche dans les situations suivantes:

  • Si plus de 10 secondes se sont écoulées depuis la dernière réception d'un signal GPS.
  • Si la position de calcul d'itinéraire a changé de plus de 500 m depuis la dernière réception d'un signal GPS.

Si le SDK ne reçoit pas de signal GPS pendant une longue période, la progression sur le parcours, indiquée dans l'application par la position du chevron, peut ralentir jusqu'à s'arrêter complètement. Dans ce cas, le chevron sur la carte reste à l'emplacement indiqué par le dernier signal GPS. Le SDK ne quittera pas automatiquement le mode navigation en raison de l'absence de signal GPS. Toutefois, il est possible qu'il ne puisse pas fournir d'indications tant qu'il ne reçoit pas de nouveau signal.

Un mode hors connexion est-il disponible ?
Non, le SDK Navigation n'offre pas de mode hors connexion pour le moment. Toutefois, le SDK fournit des informations pré-mises en cache pour un trajet.

Données

Puis-je récupérer tous les arrêts/destinations d'un trajet avant de commencer l'itinéraire ?

Oui. Pour récupérer les itinéraires d'un trajet, appelez Navigator.getRouteSegments().

La navigation détaillée est-elle disponible au début d'un itinéraire ?
Oui. Le SDK Navigation fournit une liste de segments de parcours. De plus, l'utilisateur peut faire défiler la fiche de navigation dans l'en-tête pour voir chaque manœuvre.
Comment l'heure d'arrivée est-elle communiquée aux utilisateurs de l'application ?

Pour fournir des informations sur l'heure d'arrivée aux utilisateurs de l'application, procédez comme suit:

  1. Récupérez le temps et la distance de tous les points de cheminement à l'aide de Navigator.getTimeAndDistanceList().
  2. Transmettez ces informations à l'application cliente comme vous le faites pour l'heure d'arrivée estimée du conducteur.
Le RoadSnappedLocationProvider peut-il être utilisé pour obtenir l'emplacement actuel de l'utilisateur si la navigation n'est pas au premier plan ?

Oui. RoadSnappedLocationProvider s'exécute en arrière-plan par défaut.

Le SDK Navigation est-il compatible avec le géorepérage ?

Non. Dans le contexte de la navigation, remainingTimeOrdistanceChangeListener possède un avantage par rapport à une zone géographique. La zone géographique peut ne pas tenir compte de la géométrie de la route et ne pas être centrée sur le point exact vers lequel l'utilisateur se dirige.

Vous pouvez approcher cette fonctionnalité à l'aide de remainingTimeOrdistanceChangeListener.

  1. Définissez le seuil pour déterminer la fréquence des rappels.
  2. Vérifiez la distance restante jusqu'à la destination.

Par exemple, si vous définissez le seuil sur 100 m, vous recevez un rappel lorsque la distance à la destination change de 100 m. À mesure que la distance diminue, vous pouvez modifier ce seuil pour qu'il soit inférieur et recevoir des rappels plus fréquents. Ensuite, vérifiez la distance restante pour déterminer si vous êtes suffisamment proche du lieu de prise en charge/de dépôt.

Puis-je désactiver les notifications lorsque l'application Navigation est en arrière-plan ?

Oui. Utilisez Navigator.setHeadsUpNotificationEnabled pour contrôler les notifications. Cette méthode comporte un argument booléen. FALSE désactive les notifications, TRUE les active.

L'enregistreur de transactions suit les collectes et les dépôts à l'aide d'un ID unique, que Google consigne à des fins d'analyse des produits. Si vous êtes client de Mobility Services, Google vous recommande d'implémenter NavigationTransactionRecorder pour enregistrer un journal de vos transactions.

Personnalisation de l'interface utilisateur

Puis-je ajouter un code couleur à la meilleure option d'itinéraire ?
Non. Il n'est pas possible de mettre en code couleur une option d'itinéraire spécifique pour le moment.
Le SDK Navigation peut-il afficher l'heure d'arrivée prévue pour la destination finale ?

Oui. Utilisez les méthodes suivantes:

  1. Récupérez le temps et la distance de tous les points de cheminement à l'aide de Navigator.getTimeAndDistanceList().
  2. Masquez l'heure d'arrivée prévue du point de cheminement actuel à l'aide de NavigationFragment.setEtaCardEnabled(false).
  3. Afficher l'heure d'arrivée estimée à la destination finale.
Comment masquer les mises à jour de l'heure d'arrivée ?

Vous pouvez désactiver les fiches d'heure d'arrivée en appelant navigationView.setEtaCardEnabled(false).

Quelles personnalisations de l'UI sont disponibles pour les cartes d'en-tête et de pied de page ?

Utilisez StylingOptions pour définir le style de la couleur d'arrière-plan. Pour masquer ou afficher l'en-tête et le pied de page, utilisez les fonctions membres setHeaderEnabled et setFooterEnabled de NavigationFragment.

Routage

Puis-je fournir un itinéraire spécifique à un utilisateur ou supprimer d'autres itinéraires ?
Non. Par défaut, plusieurs itinéraires sont proposés, et l'itinéraire le plus rapide est prioritaire. Vous pouvez modifier l'itinéraire par défaut en ajoutant des préférences à votre requête, par exemple "éviter les autoroutes et les péages". L'ajout de points de cheminement affecte également l'itinéraire.
Puis-je afficher à l'utilisateur de l'application un libellé de destination différent de l'emplacement de destination par défaut ?

Oui. Créez un Marker avec un titre personnalisé pour la destination et la latitude/longitude. Le SDK Navigation affiche le titre personnalisé et les coordonnées sur NavigationMap.

Puis-je utiliser le SDK Navigation pour suivre les écarts par rapport à un chemin défini ?

Oui. Utilisez Navigator.setRouteChangedListener pour recevoir des notifications lorsqu'un itinéraire change ou qu'un nouvel itinéraire est recommandé:

  1. Enregistrez un écouteur qui vérifie la position de l'appareil le long du parcours à l'aide de la méthode Navigator.setRouteChangedListener.
  2. Ajoutez du code au gestionnaire d'événements de rappel, onRouteChanged :
    • Envoyez un message à l'utilisateur de l'application avec les informations sur l'heure d'arrivée estimée et la distance.
    • Suivre la position de l'appareil
    • [Facultatif] Ajoutez d'autres fonctionnalités requises par votre application pour gérer la situation lorsque l'utilisateur s'écarte du parcours prescrit.
L'utilisateur peut-il quitter la navigation sans terminer l'itinéraire ?

Oui. Appelez la méthode Navigator.stopGuidance() pour arrêter la navigation.

Simulateur

Le simulateur est-il compatible avec les modifications de parcours ?

Oui. Appelez simulateLocationsAlongNewRoute pour simuler un trajet qui inclut un changement d'itinéraire. La méthode simulateLocationsAlongExistingRoute ignore les modifications apportées au parcours existant.

Workflows

Comment ignorer la notification après avoir fermé une activité contenant un fragment de navigation ?

La notification de navigation reste visible pendant la navigation, lorsque l'activité est fermée. Lorsque le véhicule arrive à destination, la navigation s'arrête et la notification disparaît.

Pour gérer les clics sur la notification, utilisez Navigator.startGuidance(intent resumeIntent). resume intent se déclenche lorsque l'utilisateur de l'application clique sur la notification. En règle générale, Navigator.startguidance(getIntent()) est appelé à partir de l'activité principale, qui rappelle l'activité lorsque l'utilisateur de l'application clique sur la notification.

Services de mobilité

En quoi l'utilisation du SDK Navigation est-elle différente pour les clients Mobility Services ?

Les services de mobilité Google Maps Platform proposent un ensemble d'API et de SDK pour répondre aux besoins des entreprises du secteur des transports et de la logistique. Pour les clients Mobility Services, le SDK Navigation est généralement utilisé avec des services associés pour l'optimisation des itinéraires, la répartition, le suivi des tâches, l'analyse de la flotte, etc. Le SDK Navigation est également facturé différemment pour les clients Mobility Services. Pour en savoir plus, consultez la documentation sur les services de mobilité.

Les produits de mobilité ne sont actuellement disponibles que pour certains clients. Pour en savoir plus, contactez votre conseiller commercial.

Comment savoir si je suis client de Mobility Services ?
Si vous ne savez pas si vous implémentez actuellement le SDK Navigation en tant que client Mobility Services, recherchez un appel ReportBillableEvent dans votre code. Seuls les clients Mobility Services doivent appeler la méthode ReportBillableEvent.

Comment le SDK Navigation est-il facturé aux clients Mobility Services ?
Pour les clients des services Mobility, la facturation et la tarification du SDK Navigation dépendent du contrat de service que vous avez conclu avec Google Maps Platform. Pour savoir comment vous assurer que votre implémentation des services de mobilité est facturée correctement, consultez Validation de la facturation. Pour en savoir plus sur la facturation des services de mobilité, contactez votre conseiller commercial.

Quelles API du SDK de navigation ne doivent être utilisées que par les clients de Mobility Services ?

Plusieurs API du SDK Navigation ne sont destinées qu'aux clients Mobility Services, qui sont facturés par Google à la transaction. Si vous n'êtes pas client de Mobility Services, les méthodes suivantes ne nécessitent aucune action de votre part:

Si je suis client Mobility Services, puis-je également utiliser une implémentation du SDK Navigation autre que Mobility Services ?

Oui, les clients des services de mobilité peuvent utiliser à la fois les implémentations du SDK Navigation pour les services de mobilité et les autres implémentations. Toutefois, vous ne pouvez utiliser qu'un seul type d'implémentation dans une application à la fois. Vous devez également créer un projet, un compte de facturation et une clé API Google Cloud distincts de ceux que vous utilisez pour l'implémentation de vos services de mobilité. Pour en savoir plus, consultez la présentation de la configuration du SDK Navigation.

Pour en savoir plus sur l'utilisation d'une implémentation du SDK Navigation autre que Mobility Services, y compris sur la migration d'une application d'un type d'implémentation à un autre, contactez votre responsable de compte Google.

Remarque: Si vous n'êtes pas actuellement client de Mobility Services et que vous souhaitez en savoir plus sur la collection d'API et de SDK Mobility Services, contactez l'équipe commerciale de Google Maps Platform.