溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

利用HTML5定位功能,實(shí)現(xiàn)在百度地圖上定位

發(fā)布時(shí)間:2020-08-03 09:42:05 來源:網(wǎng)絡(luò) 閱讀:20301 作者:wbbhacker 欄目:移動(dòng)開發(fā)

                   利用HTML5定位功能,實(shí)現(xiàn)在百度地圖上定位

代碼如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>HTML5定位</title>
    <script type="text/javascript" src="http://lib.sinaapp.com/js/jquery/1.7.2/jquery.min.js"></script>
  <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=wqBXfIN3HkpM1AHKWujjCdsi"></script>
  <script type="text/javascript" src="http://developer.baidu.com/map/jsdemo/demo/convertor.js"></script>
    <style type="text/css">
    *{ margin: 0px; padding: 0px;}
  body{text-align: center;  height: 100%;overflow:hidden;}
  #allmap{ width: 100%;height: 100%; position: absolute;}
    </style>
</head>
<body>
    <div id="allmap"></div>
<script type="text/javascript">
 $(function(){
     if(supportsGeoLocation()){
         alert("你的瀏覽器支持 GeoLocation.");
     }else{
         alert("不支持 GeoLocation.")
     }
  // 檢測瀏覽器是否支持HTML5
               function supportsGeoLocation(){
                  return !!navigator.geolocation;
              }  
  // 單次位置請求執(zhí)行的函數(shù)             
               function getLocation(){
                  navigator.geolocation.getCurrentPosition(mapIt,locationError);
               }
  //定位成功時(shí),執(zhí)行的函數(shù)
              function mapIt(position){ 
                var lon = position.coords.longitude;
                   var lat = position.coords.latitude;
                   // alert("您位置的經(jīng)度是:"+lon+" 緯度是:"+lat);
                var map = new BMap.Map("allmap");
                var point = new BMap.Point(""+lon+"",""+lat+"");
                map.centerAndZoom(point,19);
                var gc = new BMap.Geocoder();
                      translateCallback = function (point){
                          var marker = new BMap.Marker(point);
                          map.addOverlay(marker);
                          map.setCenter(point);
                          gc.getLocation(point, function(rs){
                                var addComp = rs.addressComponents;
                                if(addComp.province!==addComp.city){
                                  var sContent =
                                  "<div><h5 style='margin:0 0 5px 0;padding:0.2em 0'>你當(dāng)前的位置是:</h5>" + 
                                  "<p style='margin:0;line-height:1.5;font-size:13px;text-indent:2em'>"+addComp.province + ", " + addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber+"</p>" + 
                                  "</div>";}
                                else{
                                  var sContent =
                                  "<div><h5 style='margin:0 0 5px 0;padding:0.2em 0'>你當(dāng)前的位置是:</h5>" + 
                                  "<p style='margin:0;line-height:1.5;font-size:13px;text-indent:2em'>"+ addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber+"</p>" + 
                                  "</div>";
                                }
                                var infoWindow = new BMap.InfoWindow(sContent);
                                map.openInfoWindow(infoWindow,point);
                          }); 
                      }                    
                  BMap.Convertor.translate(point,0,translateCallback); 
            }
  // 定位失敗時(shí),執(zhí)行的函數(shù)
               function locationError(error)
              {
              switch(error.code)
                {
                case error.PERMISSION_DENIED:
                  alert("User denied the request for Geolocation.");
                  break;
                case error.POSITION_UNAVAILABLE:
                   alert("Location information is unavailable.");
                  break;
                case error.TIMEOUT:
                   alert("The request to get user location timed out.");
                  break;
                case error.UNKNOWN_ERROR:
                   alert("An unknown error occurred.");
                  break;
                }
              }
  // 頁面加載時(shí)執(zhí)行g(shù)etLocation函數(shù)
  window.onload = getLocation;  
        })
</script>
</body>
</html>

 測試瀏覽器:ie11定位成功率100%,Safari定位成功率97%。其它瀏覽器暫時(shí)不行,HTML5獲取不了地理位置信息。


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI