12 KiB
cordova-plugin-geolocation
Este plugin proporciona información sobre la ubicación del dispositivo, tales como la latitud y longitud. Fuentes comunes de información de localización incluyen el sistema de posicionamiento Global (GPS) y ubicación deducido de las señales de la red como dirección IP, direcciones de RFID, WiFi y Bluetooth MAC y celulares GSM/CDMA IDs. No hay ninguna garantía de que la API devuelve la ubicación real del dispositivo.
Esta API se basa en la Especificación de API de geolocalización W3C y sólo se ejecuta en dispositivos que ya no proporcionan una implementación.
ADVERTENCIA: recopilación y uso de datos de geolocalización plantea cuestiones de privacidad importante. Política de privacidad de su aplicación debe discutir cómo la aplicación utiliza los datos de geolocalización, si se comparte con cualquiera de las partes y el nivel de precisión de los datos (por ejemplo, código postal grueso, fino, nivel, etc.). Datos de geolocalización es generalmente considerados sensibles porque puede revelar paradero del usuario y, si está almacenado, la historia de sus viajes. Por lo tanto, además de política de privacidad de la app, fuertemente considere dar un aviso de just-in-time antes de la aplicación tiene acceso a datos de geolocalización (si el sistema operativo del dispositivo ya no hacerlo). Que el aviso debe proporcionar la misma información mencionada, además de obtener un permiso del usuario (por ejemplo, presentando opciones para Aceptar y No gracias). Para obtener más información, por favor consulte a la guía de privacidad.
Este plugin define un global navigator.geolocation
objeto (para plataformas donde falta lo contrario).
Aunque el objeto está en el ámbito global, características proporcionadas por este plugin no están disponibles hasta después de la deviceready
evento.
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
console.log("navigator.geolocation works well");
}
Instalación
Esto requiere cordova 5.0 + (1.0.0 estable actual)
cordova plugin add cordova-plugin-geolocation
Las versiones más antiguas de Córdoba todavía pueden instalar mediante el id obsoleto (0.3.12 rancio)
Cordova plugin agregar org.apache.cordova.geolocation
También es posible instalar directamente vía url repo (inestable)
cordova plugin add https://github.com/apache/cordova-plugin-geolocation.git
Plataformas soportadas
- Amazon fire OS
- Android
- BlackBerry 10
- Firefox OS
- iOS
- Tizen
- Windows Phone 7 y 8
- Windows 8
- Windows
Métodos
- navigator.geolocation.getCurrentPosition
- navigator.geolocation.watchPosition
- navigator.geolocation.clearWatch
Objetos (sólo lectura)
- Position
- PositionError
- Coordinates
navigator.geolocation.getCurrentPosition
Devuelve la posición actual del dispositivo a la geolocationSuccess
"callback" con un Position
objeto como parámetro. Si hay un error, el geolocationError
"callback" pasa un PositionError
objeto.
navigator.geolocation.getCurrentPosition (geolocationSuccess, [geolocationError], [geolocationOptions]);
Parámetros
-
geolocationSuccess: la devolución de llamada que se pasa a la posición actual.
-
geolocationError: (opcional) la devolución de llamada que se ejecuta si se produce un error.
-
geolocationOptions: (opcional) las opciones de geolocalización.
Ejemplo
// onSuccess Callback
// This method accepts a Position object, which contains the
// current GPS coordinates
//
var onSuccess = function(position) {
alert('Latitude: ' + position.coords.latitude + '\n' +
'Longitude: ' + position.coords.longitude + '\n' +
'Altitude: ' + position.coords.altitude + '\n' +
'Accuracy: ' + position.coords.accuracy + '\n' +
'Altitude Accuracy: ' + position.coords.altitudeAccuracy + '\n' +
'Heading: ' + position.coords.heading + '\n' +
'Speed: ' + position.coords.speed + '\n' +
'Timestamp: ' + position.timestamp + '\n');
};
// onError Callback receives a PositionError object
//
function onError(error) {
alert('code: ' + error.code + '\n' +
'message: ' + error.message + '\n');
}
navigator.geolocation.getCurrentPosition(onSuccess, onError);
navigator.geolocation.watchPosition
Devuelve la posición actual del dispositivo cuando se detecta un cambio de posición. Cuando el dispositivo recupera una nueva ubicación, el geolocationSuccess
devolución de llamada se ejecuta con un Position
objeto como parámetro. Si hay un error, el geolocationError
devolución de llamada se ejecuta con un PositionError
objeto como parámetro.
var watchId = navigator.geolocation.watchPosition(geolocationSuccess,
[geolocationError],
[geolocationOptions]);
Parámetros
-
geolocationSuccess: la devolución de llamada que se pasa a la posición actual.
-
geolocationError: (opcional) la devolución de llamada que se ejecuta si se produce un error.
-
geolocationOptions: opciones (opcional) la geolocalización.
Devoluciones
- Cadena: devuelve un identificador de reloj que hace referencia el intervalo de posición del reloj. El id del reloj debe ser utilizado con
navigator.geolocation.clearWatch
para dejar de ver a los cambios de posición.
Ejemplo
// onSuccess Callback
// This method accepts a `Position` object, which contains
// the current GPS coordinates
//
function onSuccess(position) {
var element = document.getElementById('geolocation');
element.innerHTML = 'Latitude: ' + position.coords.latitude + '<br />' +
'Longitude: ' + position.coords.longitude + '<br />' +
'<hr />' + element.innerHTML;
}
// onError Callback receives a PositionError object
//
function onError(error) {
alert('code: ' + error.code + '\n' +
'message: ' + error.message + '\n');
}
// Options: throw an error if no update is received every 30 seconds.
//
var watchID = navigator.geolocation.watchPosition(onSuccess, onError, { timeout: 30000 });
geolocationOptions
Parámetros opcionales para personalizar la recuperación de la geolocalizaciónPosition
.
{ maximumAge: 3000, timeout: 5000, enableHighAccuracy: true };
Opciones
-
enableHighAccuracy: proporciona una pista que la aplicación necesita los mejores resultados posibles. De forma predeterminada, el dispositivo intentará recuperar un
Position
usando métodos basados en red. Al establecer esta propiedad entrue
dice el marco a utilizar métodos más precisos, como el posicionamiento satelital. (Boolean) -
tiempo de espera: la longitud máxima de tiempo (en milisegundos) que está permitido el paso de la llamada a
navigator.geolocation.getCurrentPosition
ogeolocation.watchPosition
hasta el correspondientegeolocationSuccess
devolución de llamada se ejecuta. Si elgeolocationSuccess
no se invoque "callback" dentro de este tiempo, elgeolocationError
devolución de llamada se pasa unPositionError.TIMEOUT
código de error. (Tenga en cuenta que cuando se utiliza en conjunción congeolocation.watchPosition
, elgeolocationError
"callback" podría ser llamado en un intervalo cadatimeout
milisegundos!) (Número) -
maximumAge: aceptar un puesto en la memoria caché, cuya edad no es mayor que el tiempo especificado en milisegundos. (Número)
Rarezas Android
Emuladores Android 2.x no devuelva un resultado de geolocalización a menos que el enableHighAccuracy
opción se establece entrue
.
navigator.geolocation.clearWatch
Deja de ver cambios en la ubicación del dispositivo al que hace referencia el watchID
parámetro.
navigator.geolocation.clearWatch(watchID);
Parámetros
- watchID: el id del intervalo
watchPosition
para despejar. (String)
Ejemplo
// Options: watch for changes in position, and use the most
// accurate position acquisition method available.
//
var watchID = navigator.geolocation.watchPosition(onSuccess, onError, { enableHighAccuracy: true });
// ...later on...
navigator.geolocation.clearWatch(watchID);
Position
Contiene Position
coordenadas y timestamp, creado por la API de geolocalización.
Propiedades
-
coordenadas: un conjunto de coordenadas geográficas. (Coordenadas)
-
timestamp: fecha y hora de creación
coords
. (DOMTimeStamp)
Coordinates
A Coordinates
objeto está unido a un Position
que está disponible para funciones de retrollamada en las solicitudes para la posición actual del objeto. Contiene un conjunto de propiedades que describen las coordenadas geográficas de posición.
Propiedades
-
Latitude: latitud en grados decimales. (Número)
-
longitud: longitud en grados decimales. (Número)
-
altitud: altura de la posición en metros por encima del elipsoide. (Número)
-
exactitud: nivel de precisión de las coordenadas de latitud y longitud en metros. (Número)
-
altitudeAccuracy: nivel de precisión de las coordenadas de altitud en metros. (Número)
-
Dirección: dirección del recorrido, especificado en grados contando hacia la derecha en relación con el norte verdadero. (Número)
-
velocidad: velocidad actual del dispositivo especificado en metros por segundo. (Número)
Amazon fuego OS rarezas
altitudeAccuracy: no compatible con dispositivos Android, regresandonull
.
Rarezas Android
altitudeAccuracy: no compatible con dispositivos Android, regresandonull
.
PositionError
El PositionError
objeto se pasa a la geolocationError
función de devolución de llamada cuando se produce un error con navigator.geolocation.
Propiedades
-
code: uno de los códigos de error predefinido enumerados a continuación.
-
mensaje: mensaje de Error que describe los detalles del error encontrado.
Constantes
PositionError.PERMISSION_DENIED
- Regresó cuando los usuarios no permiten la aplicación recuperar información de la posición. Esto depende de la plataforma.
PositionError.POSITION_UNAVAILABLE
- Regresó cuando el dispositivo es capaz de recuperar una posición. En general, esto significa que el dispositivo no está conectado a una red o no puede obtener una solución vía satélite.
PositionError.TIMEOUT
- Cuando el dispositivo es capaz de recuperar una posición dentro del tiempo especificado por el
timeout
incluido engeolocationOptions
. Cuando se utiliza connavigator.geolocation.watchPosition
, este error podría pasar repetidamente a lageolocationError
"callback" cadatimeout
milisegundos.
- Cuando el dispositivo es capaz de recuperar una posición dentro del tiempo especificado por el