教程集 www.jiaochengji.com
教程集 >  脚本编程  >  php  >  正文 PHP计算地球上两点之间的距离(示例详解)

PHP计算地球上两点之间的距离(示例详解)

发布时间:2021-01-12   编辑:jiaochengji.com
教程集为您提供PHP计算地球上两点之间的距离(示例详解)等资源,欢迎您收藏本站,我们将为您提供最新的PHP计算地球上两点之间的距离(示例详解)资源
给定经度和纬度,求地球上两点之间的距离。首先我们需要了解该问题的解决思路,然后再用PHP代码来实现计算。

此问题可以用半正矢(haversine)公式求解:

大圆距离或正交距离是球面(或地球表面)上两点之间最短的距离。为了使用这种方法,我们需要有点A和点B的坐标。大圆法优于其他方法。

首先,将纬度和经度值从十进制度转换为弧度。因此,将经度和纬度值同时除以180 / pi。pi圆周率的值是22/7。180/pi的值约为57.29577951。如果我们想计算两个地方之间的距离(以英里为单位),就用3,963,这是地球的半径。如果我们想计算两个地方之间的距离,单位是千米,用6,378.8,也就是地球的半径。

求纬度值(以弧度为单位): 纬度值,单位为弧度,lat =纬度/ (180/pi) 或 纬度值,以弧度为单位,lat =纬度/ 57.29577951  求经度的弧度值: 经度值,单位为弧度,long =经度/ (180/pi) 或 经度值,单位为弧度,long =经度/ 57.29577951

求出点A的经纬度坐标。使用上述转换方法将经纬度值转换为弧度。我把它叫做lat1和long1。对点B的坐标做同样的处理,得到lat2和long2。

现在,为了得到点A和点B之间的距离,使用下面的公式:

距离,d = 3963.0 * arccos[(sin(lat1) * sin(lat2))   cos(lat1) * cos(lat2) * cos(long2 - long1)]

得到的距离d的单位是英里。如果你想让你的值以千米为单位,则d乘以1.609344。

d(千米)= 1.609344 * d(英里)

因此,你可以用大圆距离法得到地球上两个地方之间最短的距离。

PHP计算地球上两点间距离的实现代码如下:

<?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');

输出:

2.0043678382716137 K.M

本篇文章就是关于PHP计算地球上两点之间的距离的方法介绍,希望对需要的朋友有所帮助!

以上就是PHP计算地球上两点之间的距离(示例详解)的详细内容,更多请关注教程集其它相关文章!

  • 本文原创发布教程集,转载请注明出处,感谢您的尊重!
  • 您可能感兴趣的文章:
    PHP计算地球上两点之间的距离(示例详解)
    php计算两个经纬度地点之间距离的方法分享
    老师不会教的【DIV间距设置】技巧
    php计算距离的代码一例
    如何使用Python已知两坐标求距离?
    CSS实用教程二
    Illustrator字距调整解析分享
    python canopy是什么
    PHP计算百度地图两个GPS坐标之间的距离代码
    PHP使用Redis的GEO(地理位置)命令

    [关闭]
    ~ ~