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