精品免费在线观看-精品欧美-精品欧美成人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; 
}
返回頂部
主站蜘蛛池模板: 成人免费国产gav视频在线 | 99青青草 | 成人免费淫片在线费观看 | 瑟瑟网站免费 | 国产夜色视频 | 亚洲视频一区二区 | 国产精品嫩草影院99av视频 | 三级毛片在线看 | 国产做人爱三级视频在线 | 欧美日韩一区二区三区高清不卡 | 亚洲国产天堂在线网址 | 视频黄色免费 | 国产一有一级毛片视频 | 在线高清视频观看vvvv | 日韩三级毛片 | 亚洲丝袜在线播放 | 日本免费毛片在线高清看 | 国产乱小说| 口国产成人高清在线播放 | 国产精品偷伦视频免费观看的 | 日本精品久久久中文字幕 | 伊人久久久综在合线久久在播 | 国产一区在线视频观看 | 91在线 | 亚洲 | 亚洲第一成年网 | 皮皮在线精品亚洲 | 首页亚洲国产丝袜长腿综合 | 国产性videostv另类极品 | 亚洲综合精品成人啪啪 | 亚洲v欧美 | 国产河南妇女毛片精品久久 | 免费黄色短视频 | 国内主播大秀福利视频在线看 | 久久久精品午夜免费不卡 | 久久精品美女视频 | 久久夜色精品国产尤物 | 日本一本高清视频 | 永久免费视频网站在线观看 | 99久久这里只精品国产免费 | 国产一级毛片午夜 | 在线观看日本免费视频大片 |