突襲HTML5之Javascript API擴展2—地理信息服務(wù)及地理位置API學習
來源:易賢網(wǎng) 閱讀:1265 次 日期:2016-07-22 14:51:15
溫馨提示:易賢網(wǎng)小編為您整理了“突襲HTML5之Javascript API擴展2—地理信息服務(wù)及地理位置API學習”,方便廣大網(wǎng)友查閱!

在HTML5中,加入了新的地理位置API用來確定和分享地理位置。這一類服務(wù)就是企業(yè)利用某點(例如用戶所在的位置)坐標附近的區(qū)域提供服務(wù)的信息,比如常見的地圖相關(guān)服務(wù),本文詳細介紹下,感興趣的朋友可以了解下,或許對你有所幫助

現(xiàn)在比較火的一類服務(wù)叫做基于位置的服務(wù)(location-based service, LBS),這一類服務(wù)就是企業(yè)利用某點(例如用戶所在的位置)坐標附近的區(qū)域提供服務(wù)的信息,比如常見的地圖相關(guān)服務(wù)。在HTML5中,加入了新的地理位置API用來確定和分享地理位置。

隱私申明

在與遠程Web服務(wù)器共享物理位置時,隱私是一個需要關(guān)注的問題。因此,地理位置API會要求用戶先提供權(quán)限,然后Web應用程序才能訪問位置信息。首次訪問請求地理位置數(shù)據(jù)的網(wǎng)頁時,瀏覽器將顯示一個通知欄,提示提供對用戶位置的訪問權(quán)限。按照瀏覽器的提示,選擇相關(guān)的授權(quán)即可。

如果用戶未授予權(quán)限,則不會向 Web 應用程序提供位置信息。調(diào)用相關(guān)API不會觸發(fā)成功回調(diào)。

檢查瀏覽器的支持情況

地理位置API在主流的瀏覽器的最新版中都支持了,但是為了兼容老的瀏覽器,還是要檢查一下。如果地理位置 API 不可用,則 window.navigator.geolocation 將為 null,如下所示:

代碼如下:

function show_islocationenabled()

{

var str = "No, geolocation is not supported.";

if (window.navigator.geolocation) {

str = "Yes, geolocation is supported.";

}

alert( str );

}

Geolocation API基于navigator這一全局對象的一個新屬性:navigator.geolocation,該對象提供了一些關(guān)于訪問者的瀏覽器和系統(tǒng)的有用信息。Geolocation的信息可以通過許多手段獲得:比如基站、web的數(shù)據(jù)庫或是GPS等。使用不同的方式獲取到的Geolocation信息精度也是不一樣的,通常情況下,通過GPS獲得的最為準確(移動平臺上使用GPS最多,PC平臺上基本都是靠網(wǎng)絡(luò)數(shù)據(jù))。偶然情況下,在一些位置上,你有可能不能獲得明確的地理位置讀數(shù)或是一點數(shù)據(jù)都接收不到。

定位當前位置

使用navigator.geolocation的getCurrentPosition()方法獲取用戶的當前位置,這個方法只獲取一次位置的信息。當該方法被腳本調(diào)用時,方法以異步的方式來嘗試獲取宿主設(shè)備的當前位置。

代碼如下:

方法簽名:getCurrentPosition(geolocationSuccessCallback,[geolocationErrorCallback,geolocationOptions]);

  1. geolocationSuccessCallback:獲取當前位置成功后的回調(diào)(必需的)

  2. geolocationErrorCallback. 有錯誤發(fā)生時使用的回調(diào)(可選的)

  3. geolocationOptions. 地理位置選項(可選的)

處理位置信息

getCurrentPositon()方法獲得當前位置成功后會將位置信息保存到一個Position對象中,然后把這個對象作為參數(shù)來執(zhí)行g(shù)eolocationSuccessCallback這一回調(diào)。在這個回調(diào)函數(shù)中,你可以任意處置這個對象中包含的信息。

Position對象有兩個屬性:timestamp和coords。timestamp屬性表示地理位置數(shù)據(jù)的創(chuàng)建時間,coords屬性表示地理位置信息,又包含七個屬性:

代碼如下:

. coords.latitude:估計緯度

. coords.longitude:估計經(jīng)度

. coords.altitude:估計高度

. coords.accuracy:所提供的以米為單位的經(jīng)度和緯度估計的精確度

. coords.altitudeAccuracy:所提供的以米為單位的高度估計的精確度

. coords.heading: 宿主設(shè)備當前移動的角度方向,相對于正北方向順時針計算

. coords.speed:以米每秒為單位的設(shè)備的當前對地速度

一般的,這些屬性中有三項是保證有的:coords.latitude、coords.longitude和coords.accuracy,其余的返回null;這取決于設(shè)備的能力和其所采用的后端定位服務(wù)器。而且,heading和speed屬性可以基于用戶之前的位置計算出來。

處理錯誤

執(zhí)行g(shù)etCurrentPositon()方法時如果有錯誤發(fā)生的話,則該方法傳遞一個PositionError對象給geolocationErrorCallback回調(diào)。

設(shè)置地理位置選項

你可以設(shè)置geolocationOptions的三個屬性:

代碼如下:

enableHighAccuracy:如果設(shè)備支持高精度的話,這個選項表示是否啟用高精度。

timeout:查詢超時時間

maximumAge: 緩存的位置最大的時間數(shù),在這一時間段內(nèi)緩存可被使用。

看下面完整的例子:

代碼如下:

<!DOCTYPE html>

<html>

<body>

<p id="demo">Click the button to get your position:</p>

<button onclick="getLocation()">Try It</button>

<div id="mapholder"></div>

<script>

var x=document.getElementById("demo");

function getLocation() {

if (navigator.geolocation){

navigator.geolocation.getCurrentPosition(showPosition,showError);

}

else{

x.innerHTML="Geolocation is not supported by this browser.";

}

}

function showPosition(position) {

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

var img_url="http://maps.googleapis.com/maps/api/staticmap?center=" +

latlon + "&zoom=9&size=400x300&sensor=false";

document.getElementById("mapholder").innerHTML="<img src='"+img_url+"' />";

}

function showError(error) {

switch(error.code) {

case error.PERMISSION_DENIED:

x.innerHTML="User denied the request for Geolocation."

break;

case error.POSITION_UNAVAILABLE:

x.innerHTML="Location information is unavailable."

break;

case error.TIMEOUT:

x.innerHTML="The request to get user location timed out."

break;

case error.UNKNOWN_ERROR:

x.innerHTML="An unknown error occurred."

break;

}

}

</script>

</body>

</html>

這個例子獲取到當前設(shè)備所在的地理位置并顯示到Google地圖中。當然你可以使用百度地圖API中的靜態(tài)圖版來改造這個例子。百度地圖API參看后面的實用參考中的鏈接。

開啟/取消持續(xù)定位

使用navigator.geolocation的watchPosition()方法可以定期輪詢用戶的位置,查看用戶的位置是否發(fā)生改變。這個方法有三個參數(shù):這三個參數(shù)和getCurrentPosition()方法一樣,一個成功后的回調(diào),一個失敗后的回調(diào),和一個獲取位置信息的選項;這個方法有一個返回值watchID,用于取消持續(xù)定位。

使用navigator.geolocation的clearWatch()方法可以終止正在進行的watchPosition(),該方法只帶一個參數(shù)watchID。

看下面的例子:

代碼如下:

<!DOCTYPE html>

<html>

<head>

<title>Geolocation API Example: Listening for Location Updates</title>

<meta http-equiv="X-UA-Compatible" content="IE=9" />

<script type="text/javascript">

function setText(val, e) {

document.getElementById(e).value = val;

}

var nav = null;

var watchID;

function listenForPositionUpdates() {

if (nav == null) {

nav = window.navigator;

}

if (nav != null) {

var geoloc = nav.geolocation;

if (geoloc != null) {

watchID = geoloc.watchPosition(successCallback);

}

else {

alert("geolocation not supported");

}

}

else {

alert("Navigator not found");

}

}

function clearWatch(watchID) {

window.navigator.geolocation.clearWatch(watchID);

}

function successCallback(position)

{

setText(position.coords.latitude, "latitude");

setText(position.coords.longitude, "longitude");

}

</script>

</head>

<body>

<label for="latitude">Latitude: </label><input id="latitude" />

<label for="longitude">Longitude: </label><input id="longitude" />

<input type="button" value="Watch Latitude and Longitude" onclick="listenForPositionUpdates()" />

<input type="button" value="Clear watch" onclick="clearWatch()" />

</body>

</html>

更多信息請查看網(wǎng)頁制作
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇剩?/div>

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)