Heim  >  Artikel  >  Web-Frontend  >  Beispiel-Tutorial zum Parsen der HTML5-Geolokalisierung

Beispiel-Tutorial zum Parsen der HTML5-Geolokalisierung

零下一度
零下一度Original
2017-05-26 16:02:581897Durchsuche

Die Github-Adresse der Testdemo: github.com/lily1010/html5_geolocation

HTML5 Geolocation API wird verwendet, um den geografischen Standort des Benutzers zu ermitteln. Da diese Funktion möglicherweise die Privatsphäre des Benutzers verletzt, sind Informationen zum Benutzerstandort nicht verfügbar, es sei denn, der Benutzer stimmt zu.

1 Browserbasierte HTML5-Suche nach geografischem Standort

Die GPS-Positionierungsfunktion in HTML5 ist im Attribut navigator.geolocation gekapselt. Es gibt drei Methoden:

(1) getCurrentPosition ruft die Position des Benutzers nur einmal ab

(2) watchPosition gibt die aktuelle Position des Benutzers zurück und gibt weiterhin die aktualisierte Position zurück, wenn sich der Benutzer bewegt (genau wie das GPS eines Autos).

(3) clearWatch() - Methode watchPosition() stoppen

Das Format der beiden Methoden getCurrentPosition und watchPosition ist

getCurrentPosition(successCallback, errorCallback, positionOptions) und watchPosition(successCallback, errorCallback, positionOptions)

(1) successCallback stellt die Callback-Funktion dar, nachdem die Funktion erfolgreich aufgerufen wurde. Diese Funktion benötigt einen Parameter, das Objektliteralformat. Angabe der Erfassung von Standortdaten des Benutzers.

HTML5 geolocation0

(2) errorCallback stellt den zurückgegebenen Fehlercode dar. Es enthält die folgenden zwei Attribute:

1、message:错误信息
2、 code:错误代码。

其中code错误代码包括以下四个值:
1 位置服务被拒绝
2 暂时获取不到位置信息
3 获取信息超时
4 未知错误

(3) Das Datenformat von positionOptions ist JSON, und es gibt drei optionale Attribute:

1、enableHighAcuracy — 布尔值: 表示是否启用高精确度模式,如果启用这种模式,浏览器在获取位置信息时可能需要耗费更多的时间。
2、timeout — 整数: 表示浏览需要在指定的时间内获取位置信息,否则触发errorCallback。
3、maximumAge — 整数/常量: 表示浏览器重新获取位置信息的时间间隔。

Mal sehen Unten finden Sie ein Testbeispiel: (Beachten Sie, dass die Positionierung aktiviert sein muss, bevor Sie den Effekt sehen können.)

<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8"/>  
    <title>基于浏览器的HTML5查找地理位置</title> 
    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" /> 
  <script>
  var options={
       enableHighAccuracy:true,   //高精度定位参数
       maximumAge:1000
   }
   function getLocation(){
       if(navigator.geolocation){
           //浏览器支持geolocation
           navigator.geolocation.getCurrentPosition(onSuccess,onError,options);  //getCurrentPosition 只获取一次用户的地理位置函数
           //onSuccess成功返回的回调函数(必选),onError失败返回的回调函数(可选),设置精确度等参数(可选options)
           
           //navigator.geolocation.watchPosition(onSuccess,onError,options);  //watchPosition 继续获取用户的位置,适合于导航
           //onSuccess成功返回的回调函数(必选),onError失败返回的回调函数(可选),设置精确度等参数(可选options)
       }else{
           //浏览器不支持geolocation
           alert (&#39;您的浏览器暂不支持定位&#39;);
       }
   }
   //成功时
   function onSuccess(position){
     //返回用户位置
     //经度
     var longitude =position.coords.longitude;
     
     //纬度
     var latitude = position.coords.latitude;
     
     //精确度
     var accuracy = position.coords.accuracy;
     
     //高度精确度
     var altitudeAccuracy = position.coords.altitudeAccuracy;
     
     //设备正北顺时针前进的方位
     var heading = position.coords.heading;
     
     //设备外部环境的移动速度(m/s)
     var speed = position.coords.speed;
     
     //当位置捕获到时的时间戳
     var timestamp = position.timestamp;
     
     document.getElementById("container").innerHTML= "您的经度是="+longitude+&#39;<br>&#39;
     +"您的纬度是="+latitude+&#39;<br>&#39;+"您的精确度是="+accuracy+&#39;<br>&#39;
     +"您的高度精确度是="+altitudeAccuracy+&#39;<br>&#39;+"您的设备正北顺时针前进的方位是="+heading+&#39;<br>&#39;
     +"您的设备外部环境的移动速度(m/s)是="+speed+&#39;<br>&#39;+"您的当位置捕获到时的时间戳是="+timestamp+&#39;<br>&#39;;
   }
   //失败时
   function onError(error){
     switch(error.code){
       case 1:alert("位置服务被拒绝");break;
       case 2:alert("暂时获取不到位置信息");break;
       case 3:alert("获取信息超时");break;
       case 4:alert("未知错误");break;
     }
   }
   window.onload=getLocation;
   </script>
</head>
<body>
   <p id="container" style="300px;height: 300px"></p>
</body>
</html>

Der obige Code lässt sich am besten auf einem Mobiltelefon testen, da Google Chrome in China blockiert ist Kennen Sie die Positionierung

2 HTML5-Geolokalisierungsaufrufe Baidu-Karten-API

Baidu-Kartenhandbuchadresse: Developer.baidu.com/map/jsdemo-mobile.htm#i7_1

Vorab beachten dass HTML5 keine genaue Positionierung hat, daher gibt es beim Anzeigen des Effekts auf der Karte immer einen Fehler von mehreren hundert Metern.

<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8"/>  
    <title>基于浏览器的HTML5查找地理位置和调取百度地图api</title> 
    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
    <!-- 百度API -->
         <script src="http://api.map.baidu.com/api?v=1.2" type="text/javascript"></script>  
  <script>
   var options={
       enableHighAccuracy:true,   //高精度定位参数
       maximumAge:1000
   }
   function getLocation(){
       if(navigator.geolocation){
           //浏览器支持geolocation
           navigator.geolocation.getCurrentPosition(onSuccess,onError,options);  //getCurrentPosition 只获取一次用户的地理位置函数
           //onSuccess成功返回的回调函数(必选),onError失败返回的回调函数(可选),设置精确度等参数(可选options)
           
           //navigator.geolocation.watchPosition(onSuccess,onError,options);  //watchPosition 继续获取用户的位置,适合于导航
           //onSuccess成功返回的回调函数(必选),onError失败返回的回调函数(可选),设置精确度等参数(可选options)
       }else{
           //浏览器不支持geolocation
           alert (&#39;您的浏览器暂不支持定位&#39;);
       }
   }
   //成功时
   function onSuccess(position){
     //返回用户位置
     //经度
     var longitude =position.coords.longitude;
     //纬度
     var latitude = position.coords.latitude;
     //使用百度地图API
     //创建地图实例  
     var map =new BMap.Map("container");
     //创建一个坐标
     var point =new BMap.Point(longitude,latitude);
     //地图初始化,设置中心点坐标和地图级别  
     map.centerAndZoom(point,15);
     map.addOverlay(new BMap.Marker(point)); //在地图上你的位置显示红色点点
   }
   //失败时
   function onError(error){
     switch(error.code){
       case 1:alert("位置服务被拒绝");break;
       case 2:alert("暂时获取不到位置信息");break;
       case 3:alert("获取信息超时");break;
       case 4:alert("未知错误");break;
     }
   }
   window.onload=getLocation;
   </script>
</head>
<body>
   <p id="container" style="300px;height: 300px"></p>
</body>
</html>

Der obige Code wurde auf dem Mobiltelefon getestet. Der Fehler ist etwas groß . Es ist immer noch nicht für die genaue Positionierung in der Stadt geeignet.

【Verwandte Empfehlungen】

Kostenloses h5-Online-Video-Tutorial 🎜>2. Beispielcode für HTML5-Geolocation-APIs

3. html5 navigator.geolocation ruft den geografischen Standortcode basierend auf dem Browser ab

4. HTML5-Anleitung (4) – Detaillierte Erläuterung der Verwendung von Geolocation

5. Detaillierte Erläuterung des Html5-Geolocation-Beispielcodes zum Abrufen geografischer Standortinformationen

6. Detaillierte Erläuterung der Verwendung der Geolocation-API von HTML5

HTML5 Geolocation-API und Haversine Geodistance-Algorithmus (Grafik und Text)

Das obige ist der detaillierte Inhalt vonBeispiel-Tutorial zum Parsen der HTML5-Geolokalisierung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn