HTML5 - Géolocalisation

L'API de géolocalisation HTML5 vous permet de partager votre position avec vos sites Web préférés. Un JavaScript peut capturer votre latitude et votre longitude et peut être envoyé au serveur Web principal et effectuer des tâches sophistiquées tenant compte de l'emplacement, comme trouver des entreprises locales ou afficher votre emplacement sur une carte.

Aujourd'hui, la plupart des navigateurs et appareils mobiles prennent en charge l'API de géolocalisation. Les API de géolocalisation fonctionnent avec une nouvelle propriété de l'objet navigateur global ie. Objet de géolocalisation qui peut être créé comme suit -

var geolocation = navigator.geolocation;

L'objet de géolocalisation est un objet de service qui permet aux widgets de récupérer des informations sur l'emplacement géographique de l'appareil.

Méthodes de géolocalisation

L'objet de géolocalisation fournit les méthodes suivantes -

N ° Sr. Méthode et description
1 getCurrentPosition ()

Cette méthode récupère l'emplacement géographique actuel de l'utilisateur.

2 watchPosition ()

Cette méthode récupère des mises à jour périodiques sur l'emplacement géographique actuel de l'appareil.

3 clearWatch ()

Cette méthode annule un appel watchPosition en cours.

Exemple

Voici un exemple de code pour utiliser l'une des méthodes ci-dessus -

function getLocation() {
   var geolocation = navigator.geolocation;
   geolocation.getCurrentPosition(showLocation, errorHandler);
}

Ici, showLocation et errorHandler sont des méthodes de rappel qui seraient utilisées pour obtenir la position réelle comme expliqué dans la section suivante et pour gérer les erreurs s'il y en a.

Propriétés de l'emplacement

Les méthodes de géolocalisation getCurrentPosition () et getPositionUsingMethodName () spécifient la méthode de rappel qui récupère les informations d'emplacement. Ces méthodes sont appelées de manière asynchrone avec un objetPosition qui stocke les informations de localisation complètes.

le Positionobject spécifie l'emplacement géographique actuel de l'appareil. L'emplacement est exprimé sous la forme d'un ensemble de coordonnées géographiques avec des informations sur le cap et la vitesse.

Le tableau suivant décrit les propriétés de l'objet Position. Pour les propriétés facultatives, si le système ne peut pas fournir de valeur, la valeur de la propriété est définie sur null.

Propriété Type La description
coords objets Spécifie l'emplacement géographique de l'appareil. L'emplacement est exprimé sous la forme d'un ensemble de coordonnées géographiques avec des informations sur le cap et la vitesse.
coords.latitude Nombre Spécifie l'estimation de la latitude en degrés décimaux. La plage de valeurs est [-90,00, +90,00].
coords.longitude Nombre Spécifie l'estimation de la longitude en degrés décimaux. La plage de valeurs est [-180,00, +180,00].
coords.altitude Nombre [Facultatif] Spécifie l'estimation de l'altitude en mètres au-dessus de l'ellipsoïde WGS 84.
coords.accuracy Nombre [Facultatif] Spécifie la précision des estimations de latitude et de longitude en mètres.
coords.altitudeAccuracy Nombre [Facultatif] Spécifie la précision de l'estimation d'altitude en mètres.
coords.heading Nombre [Facultatif] Spécifie la direction actuelle du mouvement de l'appareil en degrés en comptant dans le sens des aiguilles d'une montre par rapport au nord géographique.
coords.speed Nombre [Facultatif] Spécifie la vitesse sol actuelle de l'appareil en mètres par seconde.
horodatage Date Spécifie l'heure à laquelle les informations d'emplacement ont été récupérées et l'objet Position créé.

Exemple

Voici un exemple de code qui utilise l'objet Position. Ici, la méthode showLocation est une méthode de rappel -

function showLocation( position ) {
   var latitude = position.coords.latitude;
   var longitude = position.coords.longitude;
   ...
}

Traitement des erreurs

La géolocalisation est compliquée et elle est très nécessaire pour détecter toute erreur et la gérer avec élégance.

Les méthodes de géolocalisation getCurrentPosition () et watchPosition () utilisent une méthode de rappel du gestionnaire d'erreurs qui donne PositionErrorobjet. Cet objet a les deux propriétés suivantes -

Propriété Type La description
code Nombre Contient un code numérique pour l'erreur.
message Chaîne Contient une description lisible par l'homme de l'erreur.

Le tableau suivant décrit les codes d'erreur possibles renvoyés dans l'objet PositionError.

Code Constant La description
0 ERREUR INCONNUE La méthode n'a pas réussi à récupérer l'emplacement du périphérique en raison d'une erreur inconnue.
1 PERMISSION REFUSÉE La méthode n'a pas réussi à récupérer l'emplacement de l'appareil car l'application n'a pas l'autorisation d'utiliser le service de localisation.
2 POSITION_UNAVAILABLE L'emplacement de l'appareil n'a pas pu être déterminé.
3 TEMPS LIBRE La méthode n'a pas pu récupérer les informations de localisation dans le délai d'expiration maximal spécifié.

Exemple

Voici un exemple de code qui utilise l'objet PositionError. Ici, la méthode errorHandler est une méthode de rappel -

function errorHandler( err ) {
   
   if (err.code == 1) {
      
      // access is denied
   }
   ...
}

Options de position

Voici la syntaxe réelle de la méthode getCurrentPosition () -

getCurrentPosition(callback, ErrorCallback, options)

Ici, le troisième argument est le PositionOptions objet qui spécifie un ensemble d'options pour récupérer l'emplacement géographique de l'appareil.

Voici les options qui peuvent être spécifiées comme troisième argument -

Propriété Type La description
enableHighAccuracy Booléen Spécifie si le widget souhaite recevoir l'estimation d'emplacement la plus précise possible. Par défaut, c'est faux.
temps libre Nombre La propriété timeout correspond au nombre de millisecondes que votre application Web est prête à attendre pour une position.
maximumAge Nombre Spécifie l'heure d'expiration en millisecondes des informations d'emplacement mises en cache.

Exemple

Voici un exemple de code qui montre comment utiliser les méthodes mentionnées ci-dessus -

function getLocation() {
   var geolocation = navigator.geolocation;
   geolocation.getCurrentPosition(showLocation, errorHandler, {maximumAge: 75000});
}