php 计算两点地理坐标的距离

WBOY
发布: 2016-08-08 09:19:34
原创
1287 人浏览过

功能:根据圆周率地球半径系数与两点坐标的经纬度,计算两点之间的球面距离。
获取两点坐标距离:

/** * 计算两点地理坐标之间的距离 * @param Decimal $longitude1 起点经度 * @param Decimal $latitude1 起点纬度 * @param Decimal $longitude2 终点经度 * @param Decimal $latitude2 终点纬度 * @param Int $unit 单位 1:米 2:公里 * @param Int $decimal 精度 保留小数位数 * @return Decimal */functiongetDistance($longitude1, $latitude1, $longitude2, $latitude2, $unit=2, $decimal=2){$EARTH_RADIUS = 6370.996; // 地球半径系数$PI = 3.1415926; $radLat1 = $latitude1 * $PI / 180.0; $radLat2 = $latitude2 * $PI / 180.0; $radLng1 = $longitude1 * $PI / 180.0; $radLng2 = $longitude2 * $PI /180.0; $a = $radLat1 - $radLat2; $b = $radLng1 - $radLng2; $distance = 2 * asin(sqrt(pow(sin($a/2),2) + cos($radLat1) * cos($radLat2) * pow(sin($b/2),2))); $distance = $distance * $EARTH_RADIUS * 1000; if($unit==2){ $distance = $distance / 1000; } return round($distance, $decimal); } // 起点坐标$longitude1 = 113.330405; $latitude1 = 23.147255; // 终点坐标$longitude2 = 113.314271; $latitude2 = 23.1323; $distance = getDistance($longitude1, $latitude1, $longitude2, $latitude2, 1); echo$distance.'m'; // 2342.38m$distance = getDistance($longitude1, $latitude1, $longitude2, $latitude2, 2); echo$distance.'km'; // 2.34km?>
登录后复制

版权声明:本文为博主原创文章,未经博主允许不得转载。

以上就介绍了php 计算两点地理坐标的距离,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!