Maison > interface Web > tutoriel HTML > le corps du texte

Exemple HTML5 d'obtention de la position géographique actuelle et de son affichage sur la carte Baidu

jacklove
Libérer: 2018-06-20 17:25:57
original
3068 Les gens l'ont consulté

1.HTML5 obtient l'emplacement géographique actuel

L'API de géolocalisation HTML5 (interface de programmation d'application de géolocalisation) peut obtenir l'emplacement géographique actuel. Le téléphone mobile utilise le GPS. , et l'ordinateur Ensuite, en fonction du positionnement sur le réseau

vérifiez si le navigateur prend en charge l'API de géolocalisation HTML5

<script type="text/javascript">if(navigator.geolocation){
    alert(&#39;浏览器支持GeoLocation!&#39;);
}else{
    alert(&#39;浏览器不支持GeoLocation!&#39;);
}</script>
Copier après la connexion

fournit 3 méthodes d'appel

// 获取用户当前位置void getCurrentPosition(onSuccess, onError, options);// 持续获取用户当前位置,showLocation表示回调方法int watchPosition(showLocation, onError, options);// 取消监控, watchId 为watchPosition返回值void clearWatch(watchId);
Copier après la connexion

onSuccess Méthode de rappel après succès (obligatoire)
onError Méthode de rappel après échec (facultatif)
options Autres paramètres (facultatif) Sélectionnez)

options = {
    enableHighAccuracy, // boolean,是否要求高精度的地理信息
    timeout,            // 最大等待时间,默认0毫秒
    maximumAge          // 应用程序缓存时间}
Copier après la connexion

2. Appelez l'affichage de la carte Baidu

<!DOCTYPE html><html><head><meta charset="utf-8"/>  <title>基于HTML5查找地理位置并调用百度API展示</title> <script type="text/javascript" src="http://api.map.baidu.com/api?v=1.2"></script>  <script type="text/javascript">

    // 调用HTML5 GeoLocation API获取地理位置
    function getLocation(){

        document.getElementById(&#39;container&#39;).innerHTML = &#39;正在搜寻中,请稍候。。。&#39;;        var options = {
            enableHighAccuracy:true, 
            maximumAge:1000
        }        if(navigator.geolocation){            //浏览器支持geolocation
            navigator.geolocation.getCurrentPosition(onSuccess,onError,options);
        }else{            //浏览器不支持geolocation
            alert(&#39;浏览器不支持GeoLocation!&#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, 16);        // 设置标注的图标,可自己定义图标
        var icon = new BMap.Icon("http://api.map.baidu.com/img/markers.png", new BMap.Size(23, 25), {  
            offset: new BMap.Size(10, 25),              // 定位图标尺寸  
            imageOffset: new BMap.Size(0, 0 - 11 * 25)  // 设置图片偏移  
        }); 

        // 设置标注的经纬度
        var marker = new BMap.Marker(new BMap.Point(longitude,latitude),{icon:icon});        // 把标注添加到地图上
        map.addOverlay(marker);        // 设置点击事件
        marker.addEventListener("click", function(){
            alert("经度:" + longitude + ", 纬度:" + latitude);
        });
    }    // 获取失败
    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="width:640px;height:640px"></p></body></html>
Copier après la connexion

Exemple HTML5 dobtention de la position géographique actuelle et de son affichage sur la carte Baidu

Exemple HTML5 dobtention de la position géographique actuelle et de son affichage sur la carte Baidu

Cet article explique comment obtenir la situation actuelle en utilisant HTML5 Exemples de localisation géographique et d'affichage sur la carte Baidu Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois.

Recommandations associées :

Créez une classe de nombres unique via l'identifiant d'incrémentation automatique dans php

À propos de la page d'optimisation php sortie, explication des exemples compatibles avec l'accès des robots des moteurs de recherche

Appel de ffmpeg via php pour obtenir des informations vidéo

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal