HTML5 - Coğrafi Konum
HTML5 Geolocation API, konumunuzu favori web sitelerinizle paylaşmanıza olanak tanır. Bir JavaScript, enlem ve boylamınızı yakalayabilir ve arka uç web sunucusuna gönderilebilir ve yerel işletmeleri bulmak veya bir harita üzerinde konumunuzu göstermek gibi konum farkındalığıyla süslü şeyler yapabilir.
Günümüzde tarayıcıların ve mobil cihazların çoğu Geolocation API'yi desteklemektedir. Coğrafi konum API'leri, global gezgin nesnesinin yeni bir özelliğiyle yani. Aşağıdaki gibi oluşturulabilen coğrafi konum nesnesi -
var geolocation = navigator.geolocation;
Coğrafi konum nesnesi, widget'ların cihazın coğrafi konumu hakkında bilgi almasına izin veren bir hizmet nesnesidir.
Coğrafi Konum Yöntemleri
Coğrafi konum nesnesi aşağıdaki yöntemleri sağlar -
Sr.No. | Yöntem ve Açıklama |
---|---|
1 | getCurrentPosition ()
Bu yöntem, kullanıcının mevcut coğrafi konumunu alır. |
2 | watchPosition ()
Bu yöntem, cihazın mevcut coğrafi konumu hakkında periyodik güncellemeleri alır. |
3 | clearWatch ()
Bu yöntem, devam eden bir watchPosition çağrısını iptal eder. |
Misal
Aşağıda, yukarıdaki yöntemlerden herhangi birini kullanmak için örnek bir kod verilmiştir -
function getLocation() {
var geolocation = navigator.geolocation;
geolocation.getCurrentPosition(showLocation, errorHandler);
}
Burada showLocation ve errorHandler, sonraki bölümde açıklandığı gibi gerçek konumu elde etmek ve varsa hataları işlemek için kullanılacak geri arama yöntemleridir.
Konum Özellikleri
Coğrafi konum yöntemleri getCurrentPosition () ve getPositionUsingMethodName (), konum bilgilerini alan geri çağrı yöntemini belirtir. Bu yöntemler, bir nesneyle eşzamansız olarak adlandırılırPosition tam konum bilgisini saklayan.
Positionnesne, cihazın mevcut coğrafi konumunu belirtir. Konum, rota ve hız hakkındaki bilgilerle birlikte bir dizi coğrafi koordinat olarak ifade edilir.
Aşağıdaki tablo, Position nesnesinin özelliklerini açıklamaktadır. İsteğe bağlı özellikler için, sistem bir değer sağlayamazsa, özelliğin değeri null olarak ayarlanır.
Emlak | Tür | Açıklama |
---|---|---|
koordinatlar | nesneler | Cihazın coğrafi konumunu belirtir. Konum, rota ve hız hakkındaki bilgilerle birlikte bir dizi coğrafi koordinat olarak ifade edilir. |
coords.latitude | Numara | Enlem tahminini ondalık derece cinsinden belirtir. Değer aralığı [-90,00, +90,00]. |
coords.longitude | Numara | Boylam tahminini ondalık derece cinsinden belirtir. Değer aralığı [-180,00, +180,00] şeklindedir. |
coords.altitude | Numara | [İsteğe Bağlı] WGS 84 elipsoidinin üzerindeki metre cinsinden rakım tahminini belirtir. |
coords.accuracy | Numara | [İsteğe Bağlı] Enlem ve boylam tahminlerinin doğruluğunu metre cinsinden belirtir. |
coords.altitudeAccuracy | Numara | [İsteğe Bağlı] Yükseklik tahmininin doğruluğunu metre cinsinden belirtir. |
coords.heading | Numara | [İsteğe Bağlı] Aygıtın gerçek kuzeye göre saat yönünde sayarak derece cinsinden mevcut hareket yönünü belirtir. |
coords.speed | Numara | [İsteğe Bağlı] Cihazın mevcut yer hızını saniyede metre cinsinden belirtir. |
zaman damgası | tarih | Konum bilgilerinin alındığı ve Konum nesnesinin oluşturulduğu zamanı belirtir. |
Misal
Aşağıda Position nesnesini kullanan örnek bir kod verilmiştir. Burada showLocation yöntemi bir geri çağrı yöntemidir -
function showLocation( position ) {
var latitude = position.coords.latitude;
var longitude = position.coords.longitude;
...
}
Hataları Yönetme
Coğrafi konum karmaşıktır ve herhangi bir hatayı yakalamak ve incelikle ele almak çok gereklidir.
Coğrafi konum yöntemleri getCurrentPosition () ve watchPosition (), bir hata işleyicisi geri çağrı yöntemini kullanır. PositionErrornesne. Bu nesnenin aşağıdaki iki özelliği vardır -
Emlak | Tür | Açıklama |
---|---|---|
kodu | Numara | Hata için sayısal bir kod içerir. |
İleti | Dize | Hatanın insan tarafından okunabilir bir açıklamasını içerir. |
Aşağıdaki tablo, PositionError nesnesinde döndürülen olası hata kodlarını açıklamaktadır.
Kod | Sabit | Açıklama |
---|---|---|
0 | BİLİNMEYEN HATA | Yöntem, bilinmeyen bir hata nedeniyle aygıtın konumunu alamadı. |
1 | İZİN REDDEDİLDİ | Uygulamanın Konum Hizmetini kullanma izni olmadığından, yöntem aygıtın konumunu alamadı. |
2 | POSITION_UNAVAILABLE | Cihazın yeri belirlenemedi. |
3 | ZAMAN AŞIMI | Yöntem, belirtilen maksimum zaman aşımı aralığı içinde konum bilgilerini alamadı. |
Misal
Aşağıda PositionError nesnesini kullanan örnek bir kod yer almaktadır. Burada errorHandler yöntemi bir geri çağırma yöntemidir -
function errorHandler( err ) {
if (err.code == 1) {
// access is denied
}
...
}
Pozisyon Seçenekleri
GetCurrentPosition () yönteminin gerçek sözdizimi aşağıdadır -
getCurrentPosition(callback, ErrorCallback, options)
Burada üçüncü argüman şudur: PositionOptions Cihazın coğrafi konumunu almak için bir dizi seçenek belirten nesne.
Üçüncü bağımsız değişken olarak belirtilebilecek seçenekler aşağıdadır -
Emlak | Tür | Açıklama |
---|---|---|
enableHighAccuracy | Boole | Widget'ın mümkün olan en doğru konum tahminini almak isteyip istemediğini belirtir. Varsayılan olarak bu yanlıştır. |
zaman aşımı | Numara | Zaman aşımı özelliği, web uygulamanızın bir konum için beklemeye istekli olduğu milisaniye sayısıdır. |
maximumAge | Numara | Önbelleğe alınan konum bilgileri için milisaniye cinsinden sona erme süresini belirtir. |
Misal
Aşağıda, yukarıda belirtilen yöntemlerin nasıl kullanılacağını gösteren örnek bir kod verilmiştir -
function getLocation() {
var geolocation = navigator.geolocation;
geolocation.getCurrentPosition(showLocation, errorHandler, {maximumAge: 75000});
}