php根据两个经纬度坐标,计算出来两点的距离

作者:Liaodeity - 2016年10月31日

收藏一个计算经纬度两点距离的方法,在一些需要计算两点距离的一些模块中可以用到

/** 
* @desc 根据两点间的经纬度计算距离 
* @param float $lat 纬度值 
* @param float $lng 经度值 
*/ 
function getDistance($lat1, $lng1, $lat2, $lng2) 
{ 
	$earthRadius = 6367000; //approximate radius of earth in meters 

	/* 
	Convert these degrees to radians 
	to work with the formula 
	*/ 

	$lat1 = ($lat1 * pi() ) / 180; 
	$lng1 = ($lng1 * pi() ) / 180; 

	$lat2 = ($lat2 * pi() ) / 180; 
	$lng2 = ($lng2 * pi() ) / 180; 

	/* 
	Using the 
	Haversine formula 

	http://en.wikipedia.org/wiki/Haversine_formula 

	calculate the distance 
	*/ 

	$calcLongitude = $lng2 - $lng1; 
	$calcLatitude = $lat2 - $lat1; 
	$stepOne = pow(sin($calcLatitude / 2), 2) + cos($lat1) * cos($lat2) * pow(sin($calcLongitude / 2), 2); 
	$stepTwo = 2 * asin(min(1, sqrt($stepOne))); 
	$calculatedDistance = $earthRadius * $stepTwo; 

	return round($calculatedDistance); 
}


本文作者: Liaodeity

本文链接: https://www.jianbaizhan.com/article/510

版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 3.0 许可协议。转载请注明出处!


 请勿发布不友善或者负能量的内容。审查将对发布广告等违规信息进行处罚!