cordova-plugin-geolocation
Ten plugin zawiera informacje o lokalizacji urządzenia, takie jak szerokość i długość geograficzną. Najczęstsze źródła informacji o lokalizacji obejmują Global Positioning System (GPS) i lokalizacji wywnioskować z sieci sygnały, takie jak adres IP, RFID, WiFi i Bluetooth MAC adresy, a komórki GSM/CDMA identyfikatorów. Nie ma żadnej gwarancji, że API zwraca rzeczywistej lokalizacji urządzenia.
Ten interfejs API jest oparty na Specyfikacji W3C Geolocation APIi tylko wykonuje na urządzeniach, które już nie zapewniają implementacja.
Ostrzeżenie: zbierania i wykorzystywania danych geolokacyjnych podnosi kwestie prywatności ważne. Polityka prywatności danej aplikacji należy omówić, jak aplikacja używa danych, czy jest on dzielony z innych stron i poziom dokładności danych (na przykład, gruba, porządku, kod pocztowy poziom, itp.). Danych geolokacyjnych ogólnie uznaje wrażliwych, bo to może ujawnić pobytu użytkownika i, jeśli przechowywane, historii ich podróży. W związku z tym oprócz aplikacji prywatności, zdecydowanie warto powiadomienia just-in-time, zanim aplikacja uzyskuje dostęp do danych (jeśli urządzenie system operacyjny nie robi już). Że ogłoszenie powinno zawierać te same informacje, o których wspomniano powyżej, jak również uzyskanie uprawnienia użytkownika (np. poprzez przedstawianie wyborów OK i Nie dzięki). Aby uzyskać więcej informacji zobacz przewodnik prywatności.
Ten plugin definiuje obiekt globalny navigator.geolocation (dla platformy gdzie to inaczej brak).
Mimo, że obiekt jest w globalnym zasięgu, funkcji oferowanych przez ten plugin nie są dostępne dopiero po turnieju deviceready.
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
console.log("navigator.geolocation works well");
}
Instalacja
Wymaga to cordova 5.0 + (bieżącej stabilnej 1.0.0)
cordova plugin add cordova-plugin-geolocation
Starsze wersje cordova nadal można zainstalować za pomocą niezalecany identyfikator (starych 0.3.12)
cordova plugin add org.apache.cordova.geolocation
Jest również możliwość instalacji za pośrednictwem repo url bezpośrednio (niestabilny)
cordova plugin add https://github.com/apache/cordova-plugin-geolocation.git
Obsługiwane platformy
- Amazon Fire OS
- Android
- BlackBerry 10
- Firefox OS
- iOS
- Tizen
- Windows Phone 7 i 8
- Windows 8
- Windows
Metody
- navigator.geolocation.getCurrentPosition
- navigator.geolocation.watchPosition
- navigator.geolocation.clearWatch
Obiekty (tylko do odczytu)
- Position
- PositionError
- Coordinates
navigator.geolocation.getCurrentPosition
Zwraca bieżącą pozycję urządzenia do geolocationSuccess wywołanie zwrotne z Position obiektu jako parametr. Jeśli występuje błąd, wywołania zwrotnego geolocationError jest przekazywany obiekt PositionError.
navigator.geolocation.getCurrentPosition(geolocationSuccess,
[geolocationError],
[geolocationOptions]);
Parametry
-
geolocationSuccess: wywołania zwrotnego, który jest przekazywany aktualnej pozycji.
-
geolocationError: (opcjonalne) wywołania zwrotnego, która wykonuje w przypadku wystąpienia błędu.
-
geolocationOptions: (opcjonalne) opcji geolokalizacji.
Przykład
// 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
Zwraca bieżącą pozycję urządzenia po wykryciu zmiany pozycji. Gdy urządzenie pobiera nową lokalizację, wywołania zwrotnego geolocationSuccess wykonuje się z Position obiektu jako parametr. Jeśli występuje błąd, wywołania zwrotnego geolocationError wykonuje się z obiektem PositionError jako parametr.
var watchId = navigator.geolocation.watchPosition(geolocationSuccess,
[geolocationError],
[geolocationOptions]);
Parametry
-
geolocationSuccess: wywołania zwrotnego, który jest przekazywany aktualnej pozycji.
-
geolocationError: (opcjonalne) wywołania zwrotnego, która wykonuje w przypadku wystąpienia błędu.
-
geolocationOptions: (opcjonalne) geolocation opcje.
Zwraca
- Napis: zwraca identyfikator zegarek, który odwołuje się oglądać pozycji interwał. Identyfikator zegarek powinny być używane z
navigator.geolocation.clearWatchAby przestać oglądać do zmiany pozycji.
Przykład
// 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
Parametry opcjonalne dostosować pobierania geolocation Position.
{ maximumAge: 3000, timeout: 5000, enableHighAccuracy: true };
Opcje
-
enableHighAccuracy: stanowi wskazówkę, że aplikacja musi możliwie najlepszych rezultatów. Domyślnie, urządzenie próbuje pobrać
Positionprzy użyciu metody oparte na sieci. Ustawienie tej właściwości natruemówi ramach dokładniejszych metod, takich jak pozycjonowanie satelitarne. (Wartość logiczna) -
Limit czasu: maksymalna długość czas (w milisekundach), który może przekazać wywołanie
navigator.geolocation.getCurrentPositionlubgeolocation.watchPositiondo odpowiednichgeolocationSuccesswykonuje wywołanie zwrotne. JeśligeolocationSuccesswywołania zwrotnego nie jest wywoływany w tej chwili,geolocationErrorwywołania zwrotnego jest przekazywanyPositionError.TIMEOUTkod błędu. (Należy zauważyć, że w połączeniu zgeolocation.watchPosition,geolocationErrorwywołania zwrotnego można nazwać w odstępie cotimeoutmilisekund!) (Liczba) -
maximumAge: przyjąć buforowane pozycji, w których wiek jest nie większa niż określony czas w milisekundach. (Liczba)
Dziwactwa Androida
Emulatory Androida 2.x nie zwracają wynik geolocation, chyba że opcja enableHighAccuracy jest ustawiona na wartość true.
navigator.geolocation.clearWatch
Przestać oglądać zmiany położenia urządzenia określany przez parametr watchID.
navigator.geolocation.clearWatch(watchID);
Parametry
- watchID: identyfikator
watchPositionInterwał jasne. (String)
Przykład
// 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
Zawiera współrzędne Position i sygnatury czasowej, stworzony przez geolocation API.
Właściwości
-
coords: zestaw współrzędnych geograficznych. (Współrzędne)
-
timestamp: Sygnatura czasowa utworzenia dla
coords. (DOMTimeStamp)
Coordinates
Coordinates obiektu jest dołączone do Position obiektu, który jest dostępny dla funkcji wywołania zwrotnego w prośby o aktualnej pozycji. Zawiera zestaw właściwości, które opisują geograficzne współrzędne pozycji.
Właściwości
-
szerokość geograficzna: Latitude w stopniach dziesiętnych. (Liczba)
-
długość geograficzna: długość geograficzna w stopniach dziesiętnych. (Liczba)
-
wysokość: wysokość pozycji metrów nad elipsoidalny. (Liczba)
-
dokładność: poziom dokładności współrzędnych szerokości i długości geograficznej w metrach. (Liczba)
-
altitudeAccuracy: poziom dokładności Współrzędna wysokość w metrach. (Liczba)
-
pozycja: kierunek podróży, określonego w stopni licząc ruchu wskazówek zegara względem północy rzeczywistej. (Liczba)
-
prędkość: Aktualna prędkość ziemi urządzenia, określone w metrach na sekundę. (Liczba)
Amazon ogień OS dziwactwa
altitudeAccuracy: nie obsługiwane przez Android urządzeń, zwracanie wartości null.
Dziwactwa Androida
altitudeAccuracy: nie obsługiwane przez Android urządzeń, zwracanie wartości null.
PositionError
PositionError obiekt jest przekazywany do funkcji wywołania zwrotnego geolocationError, gdy wystąpi błąd z navigator.geolocation.
Właściwości
-
Kod: jeden z kodów błędów wstępnie zdefiniowanych poniżej.
-
wiadomość: komunikat o błędzie, opisując szczegóły wystąpił błąd.
Stałe
PositionError.PERMISSION_DENIED- Zwracane, gdy użytkownicy nie zezwalają aplikacji do pobierania informacji o pozycji. Jest to zależne od platformy.
PositionError.POSITION_UNAVAILABLE- Zwracane, gdy urządzenie jest w stanie pobrać pozycji. Ogólnie rzecz biorąc oznacza to urządzenie nie jest podłączone do sieci lub nie może uzyskać satelita utrwalić.
PositionError.TIMEOUT- Zwracane, gdy urządzenie jest w stanie pobrać pozycji w czasie określonym przez
timeoutwgeolocationOptions. Gdy używana znavigator.geolocation.watchPosition, ten błąd może być wielokrotnie przekazywane dogeolocationErrorzwrotne cotimeoutmilisekund.
- Zwracane, gdy urządzenie jest w stanie pobrać pozycji w czasie określonym przez