PHP calculates the distance between two points geographical coordinates

WBOY
Release: 2016-08-08 09:19:34
Original
1319 people have browsed it

Function: Calculate the spherical distance between two points based on the pi ratio and the Earth radius coefficient and the longitude and latitude of the two point coordinates.
Get the coordinate distance of two points:

<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>
Copy after login

Copyright statement: This article is an original article by the blogger and may not be reproduced without the permission of the blogger.

The above introduces how to calculate the distance between two geographical coordinates in PHP, including the content. I hope it will be helpful to friends who are interested in PHP tutorials.

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!