精品免费在线观看-精品欧美-精品欧美成人bd高清在线观看-精品欧美高清不卡在线-精品欧美日韩一区二区

17站長網

17站長網 首頁 編程教程 Html5教程 查看內容

HTML5 Geolocation 地理定位

html5 Geolocation(地理定位)用于定位用戶的位置

定位用戶的位置

html5 Geolocation API 用于獲得用戶的地理位置

鑒于該特性可能侵犯用戶的隱私,除非用戶同意,否則用戶位置信息是不可用的

瀏覽器支持

Internet Explorer 9+,Firefox,Chrome,Safari 和 Opera 支持 Geolocation(地理定位).

Geolocation(地理定位)對于擁有 GPS 的設備,比如 iPhone,地理定位更加精確

使用地理定位

HTML DOM getCurrentPosition() 方法用來獲得用戶的位置

下面的范例演示了一個簡單的的地理定位,返回用戶位置的經度和緯度

var x = document.getElementById("demo");
function getLocation(){
  if (navigator.geolocation) {
     navigator.geolocation.getCurrentPosition(showPosition);  } else {
     x.innerHTML="該瀏覽器不支持獲取地理位置";    }
}
 
function showPosition(position)   {
 x.innerHTML="緯度: " + position.coords.latitude + "<br>經度: " + position.coords.longitude;      
}

 檢測瀏覽器是否支持地理定位
 如果支持,則運行 getCurrentPosition() 方法
 如果不支持,則向用戶顯示一段消息
 如果 getCurrentPosition() 運行成功,則向參數 showPosition 中規定的函數返回一個 coordinates 對象
 showPosition() 函數獲得并顯示經度和緯度

注意: 這個范例是一個非常基礎的地理定位腳本,不含錯誤處理

處理錯誤和拒絕

方法 getCurrentPosition() 的第二個參數用于處理錯誤,規定了當獲取用戶位置失敗時運行的函數

function showError(error){
    switch(error.code) {
        case error.PERMISSION_DENIED:
            x.innerHTML="用戶拒絕對獲取地理位置的請求。"
            break;
        case error.POSITION_UNAVAILABLE:
            x.innerHTML="位置信息是不可用的。"
            break;
        case error.TIMEOUT:
            x.innerHTML="請求用戶地理位置超時。"
            break;
        case error.UNKNowN_ERROR:
            x.innerHTML="未知錯誤。"
            break;
    }
}

錯誤代碼

錯誤代碼 描述
Permission denied 用戶不允許地理定位
Position unavailable 無法獲取當前位置
Timeout 操作超時

在地圖中顯示結果

如需在地圖中顯示結果,需要訪問可使用經緯度的地圖服務,比如谷歌地圖或百度地圖

function showPosition(position){
    var latlon=position.coords.latitude+","+position.coords.longitude;
    var img_url="http://maps.googleapis.com/maps/api/staticmap?center="+latlon+"&zoom=14&size=400x300&sensor=false";
    document.getElementById("mapholder").innerHTML="<img src='"+img_url+"'>";
}

上面這個范例,我們我們使用返回的經緯度數據在谷歌地圖中顯示位置(使用靜態圖像)

這個范例演示了如何使用腳本來顯示帶有標記、縮放和拖曳選項的交互式地圖

給定位置的信息

本節大部分的范例是如何在地圖上顯示用戶的位置

不過,地理定位對于給定位置的信息同樣很有用處

范例

  1. 更新本地信息

  2. 顯示用戶周圍的興趣點

  3. 交互式車載導航系統 (GPS)

getCurrentPosition() 方法 - 返回數據

若成功,則 getCurrentPosition() 方法返回對象

始終會返回 latitude、longitude 以及 accuracy 屬性

如果可用,則會返回下面的屬性

屬性 描述
coords.latitude 十進制數的緯度
coords.longitude 十進制數的經度
coords.accuracy 位置精度
coords.altitude 海拔,海平面以上以米計
coords.altitudeAccuracy 位置的海拔精度
coords.heading 方向,從正北開始以度計
coords.speed 速度,以米/每秒計
timestamp 響應的日期/時間

Geolocation 對象 - 其它有趣的方法

方法 描述
watchPosition() 返回用戶的當前位置,并繼續返回用戶移動時的更新位置
clearWatch() 停止 watchPosition() 方法

下面的范例演示儀了 watchPosition() 方法,你需要一臺精確的 GPS 設備來測試該范例

var x=document.getElementById("demo");
function getLocation(){
    if (navigator.geolocation){
        navigator.geolocation.watchPosition(showPosition);
    }else{
        x.innerHTML="該瀏覽器不支持獲取地理位置。";
    }
}
function showPosition(position){
    x.innerHTML="緯度: " + position.coords.latitude + 
    "<br>經度: " + position.coords.longitude; 
}
返回頂部
主站蜘蛛池模板: 久久午夜精品 | 2级毛片 | 香蕉看片 | 香蕉在线观看999 | 国产成人精选免费视频 | 久久 精品 一区二区 | 热久久国产欧美一区二区精品 | 香港a毛片 | 永久免费在线观看视频 | 成 人 色综合 | 九九视频只有精品 | 亚洲高清视频一区 | 高清欧美一区二区三区 | a毛片免费全部在线播放毛 a毛片免费全部播放毛 | 国产三级在线视频播放线 | 色中色综合网 | 欧美成人看片一区二区三区 | 91尤物在线视频 | 日日操狠狠干 | 国产成人综合手机在线播放 | 经典三级第一页 | 国内三级视频 | 亚洲美女久久 | 日韩一区二区三区四区区区 | 国产91久久最新观看地址 | 草莓视频caomei888 | 4虎成人 | 国产精品宅男在线观看 | 日本亚洲一区二区三区 | 看欧美黄色片 | 国产一区系列在线观看 | 精品全国在线一区二区 | 永久在线观看www免费视频 | 亚洲精品色图 | 国产高清网址 | 成人污污视频 | 国产在线观看91精品亚瑟 | 久久精品国产一区二区三区日韩 | 精品国产免费人成在线观看 | 欧美第一精品 | 特大巨黑人吊与黑人性xxxx |