地图坐标转换

这段代码提供了将中国标准GCJ02坐标转换为百度地图BD09坐标的函数`qq2baidu()`,以及将BD09坐标转换回GCJ02坐标的函数`baidu2qq()`。转换过程涉及到经纬度的数学计算,包括弧度、正弦、余弦和反正切等运算。
摘要由CSDN通过智能技术生成
/**
 * 中国正常GCJ02坐标---->百度地图BD09坐标
 * 腾讯地图用的也是GCJ02坐标
 *
 * @param double $lat
 *        	纬度
 * @param double $lng
 *        	经度
 */
function qq2baidu($lat = '', $lng = '') {
	$x_pi = 3.14159265358979324 * 3000.0 / 180.0;
	$x = $lng;
	$y = $lat;
	$z = sqrt ( $x * $x + $y * $y ) + 0.00002 * sin ( $y * $x_pi );
	$theta = atan2 ( $y, $x ) + 0.000003 * cos ( $x * $x_pi );
	$lng = $z * cos ( $theta ) + 0.0065;
	$lat = $z * sin ( $theta ) + 0.006;
	return [ 
			'lat' => $lat,
			'lng' => $lng 
	];
}

/**
 * 百度地图BD09坐标---->中国正常GCJ02坐标
 * 腾讯地图用的也是GCJ02坐标
 *
 * @param double $lat
 *        	纬度
 * @param double $lng
 *        	经度
 * @return array();
 */
function baidu2qq($lat = '', $lng = '') {
	$x_pi = 3.14159265358979324 * 3000.0 / 180.0;
	$x = $lng - 0.0065;
	$y = $lat - 0.006;
	$z = sqrt ( $x * $x + $y * $y ) - 0.00002 * sin ( $y * $x_pi );
	$theta = atan2 ( $y, $x ) - 0.000003 * cos ( $x * $x_pi );
	$lng = $z * cos ( $theta );
	$lat = $z * sin ( $theta );
	return [ 
			'lat' => $lat,
			'lng' => $lng 
	];
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值