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如何计算地球上两点之间的距离就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。

文章题目:PHP如何计算地球上两点之间的距离-创新互联
文章网址:https://www.cdcxhl.com/article18/cshsdp.html

成都网站建设公司_创新互联,为您提供手机网站建设外贸建站网站收录服务器托管网站制作网站营销

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

手机网站建设