>  기사  >  백엔드 개발  >  PHP는 두 지점의 지리적 좌표 사이의 거리를 계산합니다.

PHP는 두 지점의 지리적 좌표 사이의 거리를 계산합니다.

WBOY
WBOY원래의
2016-08-08 09:19:341321검색

기능: pi지구 반경 계수와 두 점 좌표의 위도 및 경도를 기반으로 두 점 사이의 구면 거리를 계산합니다.
두 점의 좌표 거리 구하기:

<code><span><span><?php</span><span>/**
 * 计算两点地理坐标之间的距离
 *<span> @param</span>  Decimal $longitude1 起点经度
 *<span> @param</span>  Decimal $latitude1  起点纬度
 *<span> @param</span>  Decimal $longitude2 终点经度 
 *<span> @param</span>  Decimal $latitude2  终点纬度
 *<span> @param</span>  Int     $unit       单位 1:米 2:公里
 *<span> @param</span>  Int     $decimal    精度 保留小数位数
 *<span> @return</span> Decimal
 */</span><span><span>function</span><span>getDistance</span><span>(<span>$longitude1</span>, <span>$latitude1</span>, <span>$longitude2</span>, <span>$latitude2</span>, <span>$unit</span>=<span>2</span>, <span>$decimal</span>=<span>2</span>)</span>{</span><span>$EARTH_RADIUS</span> = <span>6370.996</span>; <span>// 地球半径系数</span><span>$PI</span> = <span>3.1415926</span>;

    <span>$radLat1</span> = <span>$latitude1</span> * <span>$PI</span> / <span>180.0</span>;
    <span>$radLat2</span> = <span>$latitude2</span> * <span>$PI</span> / <span>180.0</span>;

    <span>$radLng1</span> = <span>$longitude1</span> * <span>$PI</span> / <span>180.0</span>;
    <span>$radLng2</span> = <span>$longitude2</span> * <span>$PI</span> /<span>180.0</span>;

    <span>$a</span> = <span>$radLat1</span> - <span>$radLat2</span>;
    <span>$b</span> = <span>$radLng1</span> - <span>$radLng2</span>;

    <span>$distance</span> = <span>2</span> * asin(sqrt(pow(sin(<span>$a</span>/<span>2</span>),<span>2</span>) + cos(<span>$radLat1</span>) * cos(<span>$radLat2</span>) * pow(sin(<span>$b</span>/<span>2</span>),<span>2</span>)));
    <span>$distance</span> = <span>$distance</span> * <span>$EARTH_RADIUS</span> * <span>1000</span>;

    <span>if</span>(<span>$unit</span>==<span>2</span>){
        <span>$distance</span> = <span>$distance</span> / <span>1000</span>;
    }

    <span>return</span> round(<span>$distance</span>, <span>$decimal</span>);

}

<span>// 起点坐标</span><span>$longitude1</span> = <span>113.330405</span>;
<span>$latitude1</span> = <span>23.147255</span>;

<span>// 终点坐标</span><span>$longitude2</span> = <span>113.314271</span>;
<span>$latitude2</span> = <span>23.1323</span>;

<span>$distance</span> = getDistance(<span>$longitude1</span>, <span>$latitude1</span>, <span>$longitude2</span>, <span>$latitude2</span>, <span>1</span>);
<span>echo</span><span>$distance</span>.<span>'m'</span>; <span>// 2342.38m</span><span>$distance</span> = getDistance(<span>$longitude1</span>, <span>$latitude1</span>, <span>$longitude2</span>, <span>$latitude2</span>, <span>2</span>);
<span>echo</span><span>$distance</span>.<span>'km'</span>; <span>// 2.34km</span><span>?></span></span></code>

저작권 설명: 이 기사는 블로거의 원본 기사이므로 그렇지 않을 수도 있습니다. 블로거의 허락 없이 복제할 수 있습니다.

위 내용을 포함하여 PHP에서 두 지리적 좌표 사이의 거리를 계산하는 방법을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.