HTML5實現(xiàn)獲取地理位置信息并定位

這篇文章主要介紹了HTML5實現(xiàn)[獲取地理位置]信息并定位功能,本文講解了原生HTML5、百度地圖、谷歌地圖等三種獲取理位置信息并定位的方法,需要的朋友可以參考下:

HTML5提供了地理位置定位功能(Geolocation API),能確定用戶位置,我們可以借助HTML5的該特性開發(fā)基于地理位置信息的應用。本文結合實例給大家分享如何使用HTML5,借助百度、谷歌地圖接口來獲取用戶準確的地理位置信息。

如何使用HTML5地理位置定位功能

定位功能(Geolocation)是HTML5的新特性,因此只有在支持HTML5的現(xiàn)代瀏覽器上運行,特別是手持設備如iphone,地理定位更加精確。首先我們要檢測用戶設備瀏覽器是否支持地理定位,如果支持則獲取地理信息。注意這個特性可能侵犯用戶的隱私,除非用戶同意,否則用戶位置信息是不可用的,所以我們在訪問該應用時會提示是否允許地理定位,我們當然選擇允許即可。

function getLocation(){ 
  if (navigator.geolocation){ 
    navigator.geolocation.getCurrentPosition(showPosition,showError); 
  }else{ 
    alert("瀏覽器不支持地理定位。"); 
  } 
}       

上面的代碼可以知道,如果用戶設備支持地理定位,則運行 getCurrentPosition() 方法。如果getCurrentPosition()運行成功,則向參數(shù)showPosition中規(guī)定的函數(shù)返回一個coordinates對象,getCurrentPosition() 方法的第二個參數(shù)showError用于處理錯誤,它規(guī)定當獲取用戶位置失敗時運行的函數(shù)。

我們先來看函數(shù)showError(),它規(guī)定獲取用戶地理位置失敗時的一些錯誤代碼處理方式:

function showError(error){ 
  switch(error.code) { 
    case error.PERMISSION_DENIED: 
      alert("定位失敗,用戶拒絕請求地理定位"); 
      break; 
    case error.POSITION_UNAVAILABLE: 
      alert("定位失敗,位置信息是不可用"); 
      break; 
    case error.TIMEOUT: 
      alert("定位失敗,請求獲取用戶位置超時"); 
      break; 
    case error.UNKNOWN_ERROR: 
      alert("定位失敗,定位系統(tǒng)失效"); 
      break; 
  } 
} 

我們再來看函數(shù)showPosition(),調用coords的latitude和longitude即可獲取到用戶的緯度和經度。

function showPosition(position){ 
  var lat = position.coords.latitude; //緯度 
  var lag = position.coords.longitude; //經度 
  alert('緯度:'+lat+',經度:'+lag); 
} 

利用百度地圖和谷歌地圖接口獲取用戶地址

上面我們了解了HTML5的Geolocation可以獲取用戶的經緯度,那么我們要做的是需要把抽象的經緯度轉成可讀的有意義的真正的用戶地理位置信息。幸運的是百度地圖和谷歌地圖等提供了這方面的接口,我們只需要將HTML5獲取到的經緯度信息傳給地圖接口,則會返回用戶所在的地理位置,包括省市區(qū)信息,甚至有街道、門牌號等詳細的地理位置信息。
我們首先在頁面定義要展示地理位置的div,分別定義id#baidu_geo和id#google_geo。我們只需修改關鍵函數(shù)showPosition()。先來看百度地圖接口交互,我們將經緯度信息通過Ajax方式發(fā)送給百度地圖接口,接口會返回相應的省市區(qū)街道信息。百度地圖接口返回的是一串JSON數(shù)據,我們可以根據需求將需要的信息展示給div#baidu_geo。注意這里用到了jQuery庫,需要先加載jQuery庫文件。


function
 showPosition(position){ 
  var latlon = position.coords.latitude+','+position.coords.longitude;
//baidu
var url = "<a ; 

  
$.ajax({ 

    
type: 
"GET"
, 

    
dataType: 
"jsonp"
, 

    
url: url, 

      
beforeSend: 
function
(){ 

        
$(
"#baidu_geo"
).html(
'正在定位...'
); 

      
}, 

      
success: 
function
 (json) { 

        
if
(json.status==0){ 

          
$(
"#baidu_geo"
).html(json.result.formatted_address); 

        
} 

      
}, 

      
error: 
function
 (XMLHttpRequest, textStatus, errorThrown) { 

        
$(
"#baidu_geo"
).html(latlon+
"地址位置獲取失敗"
); 

    
} 

  
}); 

}); 

再來看谷歌地圖接口交互

同樣我們將經緯度信息通過Ajax方式發(fā)送給谷歌地圖接口,接口會返回相應的省市區(qū)街道詳細信息。谷歌地圖接口返回的也是一串JSON數(shù)據,這些JSON數(shù)據比百度地圖接口返回的要更詳細,我們可以根據需求將需要的信息展示給div#google_geo。

function
 showPosition(position){ 

  
var
 latlon = position.coords.latitude+
','
+position.coords.longitude; 

 
  
//google 

  
var
 url = 
'[http://maps.google.cn/maps/api/geocode/json?latlng=](http://qianduandu.com/redirect/aHR0cDovL21hcHMuZ29vZ2xlLmNuL21hcHMvYXBpL2dlb2NvZGUvanNvbj9sYXRsbmc9)'
+latlon+
'&language=CN'
; 

  
$.ajax({ 

    
type: 
"GET"
, 

    
url: url, 

    
beforeSend: 
function
(){ 

      
$(
"#google_geo"
).html(
'正在定位...'
); 

    
}, 

    
success: 
function
 (json) { 

      
if
(json.status==
'OK'
){ 

      
var
 results = json.results; 

        
$.each(results,
function
(index,array){ 

          
if
(index==0){ 

            
$(
"#google_geo"
).html(array[
'formatted_address'
]); 

          
} 

        
}); 

      
} 

    
}, 

    
error: 
function
 (XMLHttpRequest, textStatus, errorThrown) { 

      
$(
"#google_geo"
).html(latlon+
"地址位置獲取失敗"
); 

    
} 

  
}); 

}

以上的代碼分別將百度地圖接口和谷歌地圖接口整合到函數(shù)showPosition()中,我們可以根據實際情況進行調用。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容