• html5获取自己定位的方法


    html5获取自己定位的方法
    直接用高德地图api 不要用百度地图api 不准确


    <pre>
    <!doctype html>
    <html>
    <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no, width=device-width">
    <title>浏览器定位</title>
    <link rel="stylesheet" href="http://cache.amap.com/lbs/static/main1119.css"/>
    <script type="text/javascript"
    src="http://webapi.amap.com/maps?v=1.3&key=00955dce4bad4be3ec81058776e0e307"></script>
    <script type="text/javascript" src="http://cache.amap.com/lbs/static/addToolbar.js"></script>
    <body>

    <div style="30px; height:30px; background: #000; position: absolute;left:10px; top:10px;z-index: 9999" class="dss" onclick="getdingwei();"></div>
    <div id="result"></div>
    <div id='container' style="display: none"></div>
    <div id="tip"></div>
    <script type="text/javascript">

    function regeocoder(lnglatXY) { //逆地理编码
    var geocoder = new AMap.Geocoder({
    radius: 1000,
    extensions: "all"
    });
    geocoder.getAddress(lnglatXY, function(status, result) {
    if (status === 'complete' && result.info === 'OK') {
    geocoder_CallBack(result);
    }
    });
    var marker = new AMap.Marker({ //加点
    map: map,
    position: lnglatXY
    });
    }
    function geocoder_CallBack(data) {
    var address = data.regeocode.formattedAddress; //返回地址描述
    document.getElementById("result").innerHTML = address;
    }
    function getdingwei() {
    map.plugin('AMap.Geolocation', function() {
    geolocation = new AMap.Geolocation({
    enableHighAccuracy: true,//是否使用高精度定位,默认:true
    timeout: 10000, //超过10秒后停止定位,默认:无穷大
    buttonOffset: new AMap.Pixel(10, 20),//定位按钮与设置的停靠位置的偏移量,默认:Pixel(10, 20)
    zoomToAccuracy: true, //定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:false
    buttonPosition:'RB'
    });
    map.addControl(geolocation);
    geolocation.getCurrentPosition();
    AMap.event.addListener(geolocation, 'complete', onComplete);//返回定位信息
    AMap.event.addListener(geolocation, 'error', onError); //返回定位出错信息
    });
    }

    /***************************************
    由于Chrome、IOS10等已不再支持非安全域的浏览器定位请求,为保证定位成功率和精度,请尽快升级您的站点到HTTPS。
    ***************************************/
    var map, geolocation;
    //加载地图,调用浏览器定位服务
    map = new AMap.Map('container', {
    resizeEnable: true
    });

    //解析定位结果
    function onComplete(data) {
    lnglatXY = [data.position.getLng(), data.position.getLat()]; //已知点坐标
    regeocoder(lnglatXY);
    var str=['定位成功'];
    str.push('经度:' + data.position.getLng());
    str.push('纬度:' + data.position.getLat());
    if(data.accuracy){
    str.push('精度:' + data.accuracy + ' 米');
    }//如为IP精确定位结果则没有精度信息
    str.push('是否经过偏移:' + (data.isConverted ? '是' : '否'));
    document.getElementById('tip').innerHTML = str.join('<br>');
    }
    //解析定位错误信息
    function onError(data) {
    document.getElementById('tip').innerHTML = '定位失败';
    }
    </script>
    </body>
    </html>
    </pre>
    直接点黑色方块就可以获取定位 pc和浏览器都支持
    ps:别用谷歌浏览器的那个模拟手机端的机制测试 会定位失败

  • 相关阅读:
    Docker入门
    15个Docker基本命令及用法
    Docker系列
    docker
    Docker 常用命令
    查看用户列表在Linux
    Spring boot Mybatis
    CountDownLatch和CyclicBarrier 专题
    Spring Boot MyBatis 连接数据库
    Spring Boot MyBatis 通用Mapper插件集成 good
  • 原文地址:https://www.cnblogs.com/newmiracle/p/11871342.html
Copyright © 2020-2023  润新知