Geolocation获取当前位置的经纬度在百度地图中就是比google地图中精确的原因

同样的Geolocation中经纬度百度地图就是比google地图精确,原因是GCJ-02,原来就是他影响google地图定位的精确性,都是它惹的祸。

我承认我知道的太多了,感谢国家感谢党。

百度地图位置服务源码如下:

html

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
body, html,#allmap {width: 100%;height: 100%;overflow: hidden;margin:0;}
#l-map{height:100%;width:78%;float:left;border-right:2px solid #bcbcbc;}
#r-result{height:100%;width:20%;float:left;}
</style>
<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.3"></script>
<title>浏览器定位</title>
</head>
<body>
<div id="allmap"></div>
</body>
</html>

Javascript

<script type="text/javascript">
var map = new BMap.Map("allmap");
var point = new BMap.Point(121.473754,31.23037);
map.centerAndZoom(point,20);

var geolocation = new BMap.Geolocation();

var gc = new BMap.Geocoder(); 

geolocation.getCurrentPosition(function(r){
    if(this.getStatus() == BMAP_STATUS_SUCCESS){
        var mk = new BMap.Marker(r.point);
        map.addOverlay(mk);
        map.panTo(r.point);
        alert('您的位置:'+r.point.lng+','+r.point.lat);		
		
		var pt = r.point;
		var message = "";
		gc.getLocation(pt, function(rs){
			var addComp = rs.addressComponents;
			alert(addComp.province + addComp.city + addComp.district + addComp.street + addComp.streetNumber);

			var opts = {
			  width : 250,     // 信息窗口宽度
			  height: 50,     // 信息窗口高度
			  title : "当前位置:"  // 信息窗口标题
			}
			var infoWindow = new BMap.InfoWindow(addComp.province + addComp.city + addComp.district + addComp.street + addComp.streetNumber, opts);  // 创建信息窗口对象
			map.openInfoWindow(infoWindow,r.point); //开启信息窗口

			mk.addEventListener("click", function(){map.openInfoWindow(infoWindow,r.point);});

		});     

		
    }
    else {
        alert('failed'+this.getStatus());
    }        
})

map.enableScrollWheelZoom(true);
map.addControl(new BMap.ScaleControl());                    // 添加默认比例尺控件
map.addControl(new BMap.NavigationControl());  //添加默认缩放平移控件

//关于状态码
//BMAP_STATUS_SUCCESS	检索成功。对应数值“0”。
//BMAP_STATUS_CITY_LIST	城市列表。对应数值“1”。
//BMAP_STATUS_UNKNOWN_LOCATION	位置结果未知。对应数值“2”。
//BMAP_STATUS_UNKNOWN_ROUTE	导航结果未知。对应数值“3”。
//BMAP_STATUS_INVALID_KEY	非法密钥。对应数值“4”。
//BMAP_STATUS_INVALID_REQUEST	非法请求。对应数值“5”。
//BMAP_STATUS_PERMISSION_DENIED	没有权限。对应数值“6”。(自 1.1 新增)
//BMAP_STATUS_SERVICE_UNAVAILABLE	服务不可用。对应数值“7”。(自 1.1 新增)
//BMAP_STATUS_TIMEOUT	超时。对应数值“8”。(自 1.1 新增)
</script>

百度地图api

setTimeout(function(){
    BMap.Convertor.translate(ggPoint,2,translateCallback);     //GCJ-02坐标转成百度坐标
}, 2000);


  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值