`
soundhorizon
  • 浏览: 55326 次
  • 性别: Icon_minigender_1
  • 来自: 徐州
社区版块
存档分类
最新评论

根据经纬度计算距离的公式、百度坐标转换成GPS坐标(PHP版)

 
阅读更多
<?php
//百度坐标转换成GPS坐标
$lnglat = '121.437518,31.224665';
function FromBaiduToGpsXY($lnglat){
	// 经度,纬度
	$lnglat = explode(',',$lnglat);
	list($x,$y) = $lnglat;
	$Baidu_Server = "http://api.map.baidu.com/ag/coord/convert?from=0&to=4&x={$x}&y={$y}";
	$result = @file_get_contents($Baidu_Server);
	$json = json_decode($result);
	if($json->error == 0)
	{
		$bx = base64_decode($json->x);	
		$by = base64_decode($json->y);
		$GPS_x = 2 * $x - $bx;
		$GPS_y = 2 * $y - $by;
		return $GPS_x.','.$GPS_y;//经度,纬度
	}
        else
          return  $lnglat;
}
/**********************************************/
function fn_rad($d)
{
	return $d * pi() / 180.0;
}
// 2点间算法
function P2PDistance($latlng1,$latlng2)
{
	// 纬度1,经度1 ~ 纬度2,经度2
	$latlng1 = explode(',',$latlng1);
	$latlng2 = explode(',',$latlng2);
	list($lat1,$lng1) = $latlng1;
	list($lat2,$lng2) = $latlng2;
	$EARTH_RADIUS = 6378.137;
	$radLat1 = fn_rad($lat1);
	$radLat2 = fn_rad($lat2);
	$a = $radLat1 - $radLat2;
    $b = fn_rad($lng1) - fn_rad($lng2);
	$s = 2 * asin(sqrt(pow(sin($a/2),2) + cos($radLat1)*cos($radLat2)*pow(sin($b/2),2)));
	$s = $s * $EARTH_RADIUS;
	$s = round($s * 10000) / 10000;
	return number_format($s,2);
}
echo '百度坐标: ',$lnglat,'<br><br>','转换后GPS坐标: ',FromBaiduToGpsXY($lnglat),'<br><br>';
echo '转换前距离: ',P2PDistance('31.224286666667,121.420675','31.224665,121.437518'),'<br/>';
echo '转换后距离: ',P2PDistance('31.224286666667,121.420675','31.220157068379,121.42647022694');
?>
分享到:
评论
6 楼 sky6714686 2013-03-11  
解决方案 haotsp.com 有演示示例  你可以看看
众所周知地球是一个不规则椭圆体,GIS中的坐标系定义由基准面和地图投影两组参数确定,而基准面的定义则由特定椭球体及其对应的转换参数确定。 基准面是利用特定椭球体对特定地区地球表面的逼近,因此每个国家或地区均有各自的基准面。基准面是在椭球体基础上建立的,椭球体可以对应多个基准面,而基准面只能对应一个椭球体。意思就是无论是谷歌地图、搜搜地图还是高德地图、百度地图区别只是针对不同的大地地理坐标系标准制作的经纬度,不存在准不准的问题,大家都是准的只是参照物或者说是标准不一样。谷歌地图采用的是WGS84地理坐标系(中国范围除外),谷歌中国地图和搜搜中国地图采用的是GCJ02地理坐标系,百度采用的是BD09坐标系,而设备一般包含GPS芯片或者北斗芯片获取的经纬度为WGS84地理坐标系,为什么不统一用WGS84地理坐标系这就是国家地理测绘总局对于出版地图的要求,出版地图必须符合GCJ02坐标系标准了,也就是国家规定不能直接使用WGS84地理坐标系。所以定位大家感觉不准确很多又叫出版地图为火星地图其实只是坐标系不一样而已。这就是为什么设备采集的经纬度在地图上显示的时候经常有很大的偏差,远远超出民用GPS 10米偏移量的技术规范,于是我们就有了谷歌地图纠偏   腾讯搜搜纠偏  混合地图纠偏  百度谷歌互转存在的价值。那如何对谷歌地图纠偏、搜搜soso地图纠偏或者对百度地图纠偏呢,如果用算法目前没有太好的算法直接转换,所以大家采用的都是比对的方法吧地球划分成若干个小块找到地图的偏差量记录下来,然后根据任意经纬度找寻最接近的偏差量加上偏差量就可以实现不同地图之间的经纬度转换。现在有0.01度纠偏经纬度信息,可以提供任意格式,可以直接把经纬度偏移量调整回来。百度地图纠偏信息包含中国海域一共29,699,997条纠偏数据,谷歌地图只包含中国陆地一共12,597,551条纠偏数据。
5 楼 52788286 2013-01-07  
52788286 写道
请教大侠这个是什么原理,据我所知“from=0&to=4”是将GPS坐标转换成百度坐标(0是指GPS坐标,2指火星坐标,4指百度坐标),此处将百度坐标当GPS坐标代入,求出来是什么坐标?然后$GPS_x = 2 * $x - $bx就更加看不明白了。 望指教。



自己想明白了,理论基础是在一个小的范围内,加偏的偏移量差距不是很大,此近似算法假设在一个小的范围内,不同点的偏移量是相同的。此方法虽然精度不高,但是性价比很高,想法很巧妙。
4 楼 52788286 2013-01-06  
请教大侠这个是什么原理,据我所知“from=0&to=4”是将GPS坐标转换成百度坐标(0是指GPS坐标,2指火星坐标,4指百度坐标),此处将百度坐标当GPS坐标代入,求出来是什么坐标?然后$GPS_x = 2 * $x - $bx就更加看不明白了。 望指教。
3 楼 dying318 2012-08-28  
还有,可以直接用deg2rad函数了,效率高点
2 楼 dying318 2012-08-28  
能不能解释下为什么呢?距离计算明白,但是为什么要经过百度GPS转换,百度返回的参数为什么还要经过那种换算。不用百度转换的距离不准确是吗?但是如果我的数据本来就是从百度地图上通过点击获取经纬度得来的那还需要转换吗?
1 楼 郭碗瓢盆 2012-08-21  
很好很强大!~

相关推荐

Global site tag (gtag.js) - Google Analytics