使用Haversine公式可计算两点间球面距离,PHP通过经纬度转弧度、应用公式并结合地球半径实现,支持km/m/mi/nm单位输出,适用于附近的人等场景,需注意输入验证与性能优化。

在PHP中计算两个地理位置之间的距离,常用的方法是使用Haversine公式。该公式基于地球的球面模型,通过两点的经纬度来计算它们之间的最短球面距离,适用于大多数地理距离计算场景,比如“附近的人”、“门店距离”等功能。
Haversine 公式用于计算地球上两点间的弧长,考虑了地球曲率。其数学表达如下:
a = sin²(Δφ/2) + cos φ₁ ⋅ cos φ₂ ⋅ sin²(Δλ/2)
c = 2 ⋅ atan2(√a, √(1−a))
d = R ⋅ c
其中:
立即学习“PHP免费学习笔记(深入)”;
以下是一个封装好的 PHP 函数,用于计算两个经纬度坐标之间的距离:
function calculateDistance($lat1, $lon1, $lat2, $lon2, $unit = 'km') {
$earthRadius = [
'km' => 6371,
'm' => 6371000,
'mi' => 3959, // 英里
'nm' => 3440 // 海里
];
<pre class='brush:php;toolbar:false;'>// 转换为弧度
$lat1 = deg2rad($lat1);
$lon1 = deg2rad($lon1);
$lat2 = deg2rad($lat2);
$lon2 = deg2rad($lon2);
// 纬度和经度差
$deltaLat = $lat2 - $lat1;
$deltaLon = $lon2 - $lon1;
// Haversine 公式
$a = sin($deltaLat / 2) * sin($deltaLat / 2) +
cos($lat1) * cos($lat2) *
sin($deltaLon / 2) * sin($deltaLon / 2);
$c = 2 * atan2(sqrt($a), sqrt(1 - $a));
$distance = $earthRadius[$unit] * $c;
return $distance;}
假设你要计算北京(39.9042° N, 116.4074° E)到上海(31.2304° N, 121.4737° E)的距离:
$beijing = ['lat' => 39.9042, 'lng' => 116.4074]; $shanghai = ['lat' => 31.2304, 'lng' => 121.4737]; <p>$distance_km = calculateDistance( $beijing['lat'], $beijing['lng'], $shanghai['lat'], $shanghai['lng'], 'km' );</p><p>echo "距离: " . round($distance_km, 2) . " 公里"; // 输出:距离: 1068.35 公里</p>
函数支持多种单位输出:
根据业务需求选择合适的单位传入即可。
实际开发中还需注意以下几点:
基本上就这些。Haversine 公式简单高效,配合 PHP 的三角函数支持,能快速实现地理距离计算功能。
以上就是php如何实现地理位置距离计算_php经纬度haversine公式与单位转换的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号