如何使用 Google 地图中的 HTML5 GeoLocation API?


HTML5 地理定位 API 让你可以与自己喜欢的网站共享你的位置信息。Javascript 可以获取你的纬度和经度,并将其发送到后端 Web 服务器,还可以执行一些很炫的与位置相关的操作,例如查找本地商家或在地图上显示你的位置。地理定位坐标指定了设备的地理位置。

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

转到 https://console.developers.google.com,并获取 Google 地图的免费 API 密钥。将此密钥添加到代码中,以使地理定位正常工作。

你可以尝试运行以下代码,以使用 Google 地图中的 Geolocation API 显示当前位置 −

示例

<!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+ 浏览

启动您的事业

通过完成该课程获得认证

开始使用
广告