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});
}