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

藏色散人
发布: 2019-04-03 13:12:57
原创
5306人浏览过

给定经度和纬度,求地球上两点之间的距离。首先我们需要了解该问题的解决思路,然后再用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。

立即学习PHP免费学习笔记(深入)”;

现在,为了得到点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速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号