[转] PHP计算两个坐标之间的距离, Calculate the Distance Between Two Points in PHP
Calculate the Distance Between Two Points in PHP
There are a lot of applications where it is useful to know the distance between two coordinates. Here, you'll find a PHP function that takes the latitude and longitude of two points and returns the distance between them in both miles and metric units.
You can also use this to find the distance between two addresses by taking advantage of the Google Geotargetting API.
Here's the function:
function get_distance_between_points($latitude1, $longitude1, $latitude2, $longitude2) {
$theta = $longitude1 - $longitude2;
$miles = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2))) + (cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) * cos(deg2rad($theta)));
$miles = acos($miles);
$miles = rad2deg($miles);
$miles = $miles * 60 * 1.1515;
$feet = $miles * 5280;
$yards = $feet / 3;
$kilometers = $miles * 1.609344;
$meters = $kilometers * 1000;
return compact('miles','feet','yards','kilometers','meters');
}
调用
And here's an example of the function in action, using two coordinates in New York City:
$point1 = array('lat' => 40.770623, 'long' => -73.964367);
$point2 = array('lat' => 40.758224, 'long' => -73.917404);
$distance = get_distance_between_points($point1['lat'], $point1['long'], $point2['lat'], $point2['long']);
foreach ($distance as $unit => $value) { echo $unit.': '.number_format($value,4).'<br />'; }
The example returns the following:
miles: 2.6025 //英里
feet: 13,741.4350 //英尺
yards: 4,580.4783 //码
kilometers: 4.1884 //公里(km)
meters: 4,188.3894 //米(m)
FROM : https://inkplant.com/code/calculate-the-distance-between-two-points.php
最新文章
- XMPP学习&mdash;&mdash;3、XMPP协议学习补充
- Smarty模板技术学习
- 基于netty的微服务架构
- vim编辑格式与环境设置
- 【总结】String in Java
- MediaPlayer开发全解析
- 【CF】259 Div.1 B Little Pony and Harmony Chest
- C#中HashTable的用法示例2
- Java初学者必知 关于Java字符串问题
- 201521123115《java程序设计》第9周学习总结
- Linux中的 awk查找日志中的相关记录
- 【转】H.264中的NAL技术
- 本地图片上传与H5适配知识
- Note of Python Math
- 深入path类
- Java 复习
- yocto doc
- POJ - 2421 Constructing Roads 【最小生成树Kruscal】
- 20145317 网络对抗技术 逆向与Bof基础
- sort函数(cmp)、map用法---------------Tju_Oj_2312Help Me with the Game