给定经度和纬度,求地球上两点之间的距离。首先我们需要了解该问题的解决思路,然后再用PHP代码来实现计算。

此问题可以用半正矢(haversine)公式
求解:
大圆距离或正交距离是球面(或地球表面)上两点之间最短的距离。为了使用这种方法,我们需要有点A和点B的坐标。大圆法优于其他方法。
首先,将纬度和经度值从十进制度转换为弧度。因此,将经度和纬度值同时除以180 / pi。pi圆周率的值是22/7。180/pi的值约为57.29577951。如果我们想计算两个地方之间的距离(以英里为单位),就用3,963,这是地球的半径。如果我们想计算两个地方之间的距离,单位是千米,用6,378.8,也就是地球的半径。
1 2 3 4 5 6 7 8 9 | 求纬度值(以弧度为单位):
纬度值,单位为弧度,lat =纬度/ (180/pi)
或
纬度值,以弧度为单位,lat =纬度/ 57.29577951
求经度的弧度值:
经度值,单位为弧度,long =经度/ (180/pi)
或
经度值,单位为弧度,long =经度/ 57.29577951
|
Salin selepas log masuk
求出点A的经纬度坐标。使用上述转换方法将经纬度值转换为弧度。我把它叫做lat1和long1。对点B的坐标做同样的处理,得到lat2和long2。
现在,为了得到点A和点B之间的距离,使用下面的公式:
1 | 距离,d = 3963.0 * arccos[(sin(lat1) * sin(lat2)) + cos (lat1) * cos (lat2) * cos (long2 - long1)]
|
Salin selepas log masuk
得到的距离d的单位是英里。如果你想让你的值以千米为单位,则d乘以1.609344。
因此,你可以用大圆距离法得到地球上两个地方之间最短的距离。
PHP计算地球上两点间距离的实现代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | <?php
function twopoints_on_earth( $latitudeFrom , $longitudeFrom ,
$latitudeTo , $longitudeTo )
{
$long1 = deg2rad ( $longitudeFrom );
$long2 = deg2rad ( $longitudeTo );
$lat1 = deg2rad ( $latitudeFrom );
$lat2 = deg2rad ( $latitudeTo );
$dlong = $long2 - $long1 ;
$dlati = $lat2 - $lat1 ;
$val = pow(sin( $dlati /2),2)+ cos ( $lat1 )* cos ( $lat2 )*pow(sin( $dlong /2),2);
$res = 2 * asin(sqrt( $val ));
$radius = 3958.756;
return ( $res * $radius );
}
$latitudeFrom = 19.017656 ;
$longitudeFrom = 72.856178;
$latitudeTo = 40.7127;
$longitudeTo = -74.0059;
print_r(twopoints_on_earth( $latitudeFrom , $longitudeFrom ,
$latitudeTo , $longitudeTo ).' '.'miles');
|
Salin selepas log masuk
输出:
本篇文章就是关于PHP计算地球上两点之间的距离的方法介绍,希望对需要的朋友有所帮助!
Atas ialah kandungan terperinci PHP计算地球上两点之间的距离(示例详解). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!