PHP根据两点间的经纬度计算距离


Posted in PHP onOctober 31, 2014

这是一个不错的示例,直接贴代码,首先要知道纬度值、经度值

/** 
* @desc 根据两点间的经纬度计算距离 
* @param float $lat 纬度值 
* @param float $lng 经度值 
*/ 
function getDistance($lat1, $lng1, $lat2, $lng2) 
{ 
$earthRadius = 6367000; //approximate radius of earth in meters 

/* 
Convert these degrees to radians 
to work with the formula 
*/ 

$lat1 = ($lat1 * pi() ) / 180; 
$lng1 = ($lng1 * pi() ) / 180; 

$lat2 = ($lat2 * pi() ) / 180; 
$lng2 = ($lng2 * pi() ) / 180; 

/* 
Using the 
Haversine formula 

http://en.wikipedia.org/wiki/Haversine_formula 

calculate the distance 
*/ 

$calcLongitude = $lng2 - $lng1; 
$calcLatitude = $lat2 - $lat1; 
$stepOne = pow(sin($calcLatitude / 2), 2) + cos($lat1) * cos($lat2) * pow(sin($calcLongitude / 2), 2); 
$stepTwo = 2 * asin(min(1, sqrt($stepOne))); 
$calculatedDistance = $earthRadius * $stepTwo; 

return round($calculatedDistance); 
}
PHP 相关文章推荐
30 个很棒的PHP开源CMS内容管理系统小结
Oct 14 PHP
关于UEditor编辑器远程图片上传失败的解决办法
Aug 31 PHP
解析web文件操作常见安全漏洞(目录、文件名检测漏洞)
Jun 29 PHP
php中删除数组的第一个元素和最后一个元素的函数
Mar 07 PHP
typecho插件编写教程(五):核心代码
May 28 PHP
php魔法函数与魔法常量使用介绍
Jul 23 PHP
PHP简单实现正则匹配省市区的方法
Apr 13 PHP
PHP ajax+jQuery 实现批量删除功能实例代码小结
Dec 06 PHP
PHP实现文字写入图片功能
Feb 18 PHP
PHP+redis实现微博的拉模型案例详解
Jul 10 PHP
php5与php7的区别点总结
Oct 11 PHP
php中try catch捕获异常实例详解
Aug 06 PHP
ThinkPHP在新浪SAE平台的部署实例
Oct 31 #PHP
封装ThinkPHP的一个文件上传方法实例
Oct 31 #PHP
ThinkPHP无限级分类原理实现留言与回复功能实例
Oct 31 #PHP
ThinkPHP控制器间实现相互调用的方法
Oct 31 #PHP
ThinkPHP上使用多说评论插件的方法
Oct 31 #PHP
让ThinkPHP支持大小写url地址访问的方法
Oct 31 #PHP
set_exception_handler函数在ThinkPHP中的用法
Oct 31 #PHP
You might like
记录PHP错误日志 display_errors与log_errors的区别
2012/10/09 PHP
PHP模拟asp中response类实现方法
2015/08/08 PHP
php通过smtp邮件验证登陆的方法
2016/05/11 PHP
PHP基于rabbitmq操作类的生产者和消费者功能示例
2018/06/16 PHP
PHP7 标准库修改
2021/03/09 PHP
javascript生成/解析dom的CDATA类型的字段的代码
2007/04/22 Javascript
Jquery Change与bind事件代码
2011/09/29 Javascript
jquery文本框中的事件应用以输入邮箱为例
2014/05/06 Javascript
jQuery中unbind()方法用法实例
2015/01/19 Javascript
jQuery EasyUI基础教程之EasyUI常用组件(推荐)
2016/07/15 Javascript
JS中动态创建元素的三种方法总结(推荐)
2016/10/20 Javascript
javascript判断firebug是否开启的方法
2016/11/23 Javascript
浅谈JS验证表单文本域输入空格的问题
2017/02/14 Javascript
微信小程序动态添加分享数据
2017/06/14 Javascript
JavaScript模块模式实例详解
2017/10/25 Javascript
Python计算三维矢量幅度的方法
2015/06/15 Python
Python实现的密码强度检测器示例
2017/08/23 Python
Python程序员面试题 你必须提前准备!(答案及解析)
2018/01/23 Python
Python多重继承的方法解析执行顺序实例分析
2018/05/26 Python
Python3.0 实现决策树算法的流程
2019/08/08 Python
python中利用numpy.array()实现俩个数值列表的对应相加方法
2019/08/26 Python
使用pytorch实现论文中的unet网络
2020/06/24 Python
详解vscode实现远程linux服务器上Python开发
2020/11/10 Python
白俄罗斯女装和针织品网上商店:Presli.by
2019/10/13 全球购物
.NET初级开发工程师面试题(包括Javascript)
2012/08/22 面试题
J2EE中常用的名词进行解释
2015/11/09 面试题
建筑装饰学院室内设计专业个人自我评价
2013/12/07 职场文书
护士思想汇报
2014/01/12 职场文书
毕业自我评价
2014/02/05 职场文书
《一件运动衫》教学反思
2014/02/19 职场文书
党员干部承诺书范文
2014/03/25 职场文书
保密工作目标责任书
2014/07/28 职场文书
意向书范本
2014/07/29 职场文书
企业党建工作总结2015
2015/05/26 职场文书
Anaconda安装pytorch和paddle的方法步骤
2022/04/03 Python
win11怎么消除图标小盾牌?win11消除图标小盾牌解决方法
2022/08/05 数码科技