Rumah  >  Artikel  >  hujung hadapan web  >  html5 navigator.geolocation基于浏览器获取地理位置代码案例

html5 navigator.geolocation基于浏览器获取地理位置代码案例

黄舟
黄舟asal
2017-04-01 11:15:103440semak imbas

一、简介

      html5为window.navigator提供了geolocation属性,用于获取基于浏览器的当前用户地理位置。

      window.navigator.geolocation提供了3个方法分别是:      

void getCurrentPosition(onSuccess,onError,options);
//获取用户当前位置

int watchCurrentPosition(onSuccess,onError,options);
//持续获取当前用户位置

void clearWatch(watchId);
//watchId 为watchCurrentPosition返回的值
//取消监控


options = {
     enableHighAccuracy,//boolean 是否要求高精度的地理信息
     timeout,//获取信息的超时限制
     maximumAge//对地理信息进行缓存的时间
}
//options可以不写,为默认即可

二、position对象

      当成功获取地理位置信息时候,onsuccess方法中会返回position对象,通过这个对象可以获取地理位置的相关信息,包括:

position对象的属性:
 
latitude,//纬度

longitude,//经度

altitude,//海拔高度

accuracy,//获取纬度或者经度的精度

altitudeAccurancy,//海拔高度的精度

heading,//设备前景方向。正北方向的顺时针旋转角

speed,//设备的前进速度 m/s

timestamp,//获取地理位置信息时候的时间

三、基于google map的例子

      直接看代码:

<!DOCTYPE HTML>
<html>
<head>
    <meta charset="UTF-8">
    <title>在页面上使用google地图示例</title>
</head>
<body onload = &#39;init()&#39;>
    <div id="map" style=&#39;width:800px;height:800px;&#39;></div>
    <script type="text/javascript" src=&#39;http://maps.google.com/maps/api/js?sensor=false&#39;></script>
    <script type="text/javascript">
        function init(){
            if(navigator.geolocation){
                navigator.geolocation.getCurrentPosition(function(pos){
                        var coords = pos.coords;
                        var latlng =new google.maps.LatLng(coords.latitude,coords.longitude);
                        var options = {zoom:14,center:latlng,mapTypeId : google.maps.MapTypeId.ROADMAP};
                        var map1;
                        map1 =new google.maps.Map(document.getElementById(&#39;map&#39;),options);
                        var marker =new google.maps.Marker({
                                position : latlng,
                                map : map1
                                });
                        var infowindow =new google.maps.InfoWindow({
                               content : &#39;当前位置!&#39;
                               });
                        infowindow.open(map1,marker);
                        });
            }
        }
    </script>
    
</body>
</html>

Atas ialah kandungan terperinci html5 navigator.geolocation基于浏览器获取地理位置代码案例. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn