HTML5提供了地理位置定位功能(Geolocation API),能肯定用戶位置,咱們能夠藉助HTML5的該特性開發基於地理位置信息的應用。本文結合實例給你們分享如何使用HTML5,藉助百度、谷歌地圖接口來獲取用戶準確的地理位置信息。javascript
定位功能(Geolocation)是HTML5的新特性,所以只有在支持HTML5的現代瀏覽器上運行,特別是手持設備如iphone,地理定位更加精確。首先咱們要檢測用戶設備瀏覽器是否支持地理定位,若是支持則獲取地理信息。注意這個特性可能侵犯用戶的隱私,除非用戶贊成,不然用戶位置信息是不可用的,因此咱們在訪問該應用時會提示是否容許地理定位,咱們固然選擇容許便可。html
function getLocation(){ if (navigator.geolocation){ navigator.geolocation.getCurrentPosition(showPosition,showError) }else{ alert("瀏覽器不支持地理定位。") } }
上面的代碼能夠知道,若是用戶設備支持地理定位,則運行 getCurrentPosition() 方法。若是getCurrentPosition()運行成功,則向參數showPosition中規定的函數返回一個coordinates對象,getCurrentPosition() 方法的第二個參數showError用於處理錯誤,它規定當獲取用戶位置失敗時運行的函數。
咱們先來看函數showError(),它規定獲取用戶地理位置失敗時的一些錯誤代碼處理方式:java
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("定位失敗,定位系統失效") break } }
咱們再來看函數showPosition(),調用coords的latitude和longitude便可獲取到用戶的緯度和經度。git
function showPosition(position){ var lat = position.coords.latitude //緯度 var lag = position.coords.longitude //經度 alert('緯度:'+lat+',經度:'+lag) }
利用百度地圖和谷歌地圖接口獲取用戶地址
上面咱們瞭解了HTML5的Geolocation能夠獲取用戶的經緯度,那麼咱們要作的是須要把抽象的經緯度轉成可讀的有意義的真正的用戶地理位置信息。幸運的是百度地圖和谷歌地圖等提供了這方面的接口,咱們只須要將HTML5獲取到的經緯度信息傳給地圖接口,則會返回用戶所在的地理位置,包括省市區信息,甚至有街道、門牌號等詳細的地理位置信息。
咱們首先在頁面定義要展現地理位置的div,分別定義id#baidu_geo和id#google_geo。咱們只需修改關鍵函數showPosition()。先來看百度地圖接口交互,咱們將經緯度信息經過Ajax方式發送給百度地圖接口,接口會返回相應的省市區街道信息。百度地圖接口返回的是一串JSON數據,咱們能夠根據需求將須要的信息展現給div#baidu_geo。注意這裏用到了jQuery庫,須要先加載jQuery庫文件。ajax
function showPosition(position){ var latlon = position.coords.latitude+','+position.coords.longitude //baidu var url = "http://api.map.baidu.com/geocoder/v2/?ak=C93b5178d7a8ebdb830b9b557abce78b&callback=renderReverse&location="+latlon+"&output=json&pois=0"; $.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方式發送給谷歌地圖接口,接口會返回相應的省市區街道詳細信息。谷歌地圖接口返回的也是一串JSON數據,這些JSON數據比百度地圖接口返回的要更詳細,咱們能夠根據需求將須要的信息展現給div#google_geo。json
function showPosition(position){ var latlon = position.coords.latitude+','+position.coords.longitude //google var url = 'http://maps.google.cn/maps/api/geocode/json?latlng='+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+"地址位置獲取失敗") } }) }
以上的代碼分別將百度地圖接口和谷歌地圖接口整合到函數showPosition()中,咱們能夠根據實際狀況進行調用。固然這只是一個簡單的應用,咱們能夠根據這個簡單的示例開發出不少複雜的應用,建議用手機瀏覽器訪問DEMO演示。api