如何将 HTML5 地理位置 API 与 Google 地图共同使用?


HTML5 地理位置 API 能够让你与自己最喜欢的网站分享你的位置。Javascript 可以捕获你的纬度和经度,并将它们发送到后端 Web 服务器并执行一些炫酷的位置感知操作,比如查找本地业务或在地图上显示你的位置。地理位置坐标指定设备的地理位置。

我们将使用 getCurrentPostion() 方法获取当前位置。要使用带 Google 地图的 HTML5 地理位置获取当前位置,你需要为 Google Static Maps API 设置一个 API 密钥。

转到 https://console.developers.google.com 并获取 Google 地图的免费 API 密钥。将此密钥添加到代码中,以对其使用地理位置。

你可以尝试运行以下代码以使用带 Google 地图的 HTML5 地理位置显示当前位置 −

示例

<!DOCTYPE HTML>
<html>
   <head>
      <script type = "text/javascript">
         function showLocation(position) {
            var latitude = position.coords.latitude;
            var longitude = position.coords.longitude;
            var latlongvalue = position.coords.latitude + ","
                              + position.coords.longitude;
            var img_url = "https://maps.googleapis.com/maps/api/staticmap?center="
                          +latlongvalue+"&zoom=14&size = 400x300&key =
                          AIzaSyAa8HeLH2lQMbPeOiMlM9D1VxZ7pbGQq8o";
            document.getElementById("mapholder").innerHTML =
            "<img src ='"+img_url+"'>";
         }
         function errorHandler(err) {
            if(err.code == 1) {
               alert("Error: Access is denied!");
            }else if( err.code == 2) {
               alert("Error: Position is unavailable!");
            }
         }
         function getLocation(){
            if(navigator.geolocation){
               // timeout at 60000 milliseconds (60 seconds)
               var options = {timeout:60000};
               navigator.geolocation.getCurrentPosition
               (showLocation, errorHandler, options);
            }else{
               alert("Sorry, browser does not support geolocation!");
            }
         }
      </script>
   </head>
   <body>
      <div id="mapholder"></div>
      <form>
         <input type="button" onclick="getLocation();" value="Your Location"/>
      </form>
   </body>
</html>

更新日期: 18-May-2020

2K+ 浏览量

开启你的职业生涯

完成课程获得认证

开始
广告