百度地图应用-gps如何精准地转换成百度定位图标

出现的问题:html5获取gps数据有延迟,必须在回调函数中才能获取经纬度,所以把转换逻辑都放到回调中了。

<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
        body, html,#allmap {width: 100%;height: 100%;overflow: hidden;margin:0;}
    </style>
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=e6t46sH8uiGNSQpLRh4Emy1evqKS6W1q"></script>
    <script type="text/javascript" src="http://developer.baidu.com/map/jsdemo/demo/convertor.js"></script>
    <title>GPS转百度</title>
</head>
<body>
<div id="allmap"></div>
</body>
</html>
<script type="text/javascript">
    var xx,yy,gpsPoint;
    navigator.geolocation.getCurrentPosition(function (position) {

        var xx = position.coords.longitude;
       var  yy = position.coords.latitude;
        gpsPoint = new BMap.Point(xx,yy);
        //地图初始化
        var bm = new BMap.Map("allmap");
        bm.centerAndZoom(gpsPoint, 15);
        bm.addControl(new BMap.NavigationControl());

        //添加谷歌marker和label
        var markergps = new BMap.Marker(gpsPoint);
        bm.addOverlay(markergps); //添加GPS标注
        var labelgps = new BMap.Label("我是GPS标注哦",{offset:new BMap.Size(20,-10)});
        markergps.setLabel(labelgps); //添加GPS标注

        //坐标转换完之后的回调函数
        translateCallback = function (point){
            var marker = new BMap.Marker(point);
            bm.addOverlay(marker);
            var label = new BMap.Label("我是百度标注哦",{offset:new BMap.Size(20,-10)});
            marker.setLabel(label); //添加百度label
            bm.setCenter(point);
            alert(point.lng + "," + point.lat);
        }
        setTimeout(function(){
            BMap.Convertor.translate(gpsPoint,0,translateCallback);     //真实经纬度转成百度坐标
        }, 2000);
    });

</script>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值