PHP计算百度地图两个GPS坐标之间距离的方法
2015-01-24信息快讯网
这篇文章主要介绍了PHP计算百度地图两个GPS坐标之间距离的方法,是针对百度地图接口开发的典型应用,需要的朋友可以参考下
本文实例讲述了PHP计算百度地图两个GPS坐标之间距离的方法。分享给大家供大家参考。
具体实现方法如下:
/** * 计算两个坐标之间的距离(米) * @param float $fP1Lat 起点(纬度) * @param float $fP1Lon 起点(经度) * @param float $fP2Lat 终点(纬度) * @param float $fP2Lon 终点(经度) * @return int */ function distanceBetween($fP1Lat, $fP1Lon, $fP2Lat, $fP2Lon){ $fEARTH_RADIUS = 6378137; //角度换算成弧度 $fRadLon1 = deg2rad($fP1Lon); $fRadLon2 = deg2rad($fP2Lon); $fRadLat1 = deg2rad($fP1Lat); $fRadLat2 = deg2rad($fP2Lat); //计算经纬度的差值 $fD1 = abs($fRadLat1 - $fRadLat2); $fD2 = abs($fRadLon1 - $fRadLon2); //距离计算 $fP = pow(sin($fD1/2), 2) + cos($fRadLat1) * cos($fRadLat2) * pow(sin($fD2/2), 2); return intval($fEARTH_RADIUS * 2 * asin(sqrt($fP)) + 0.5); } /** * 百度坐标系转换成标准GPS坐系 * @param float $lnglat 坐标(如:106.426, 29.553404) * @return string 转换后的标准GPS值: */ function BD09LLtoWGS84($fLng, $fLat){ // 经度,纬度 $lnglat = explode(',', $lnglat); list($x,$y) = $lnglat; $Baidu_Server = "http://api.map.baidu.com/ag/coord/convert?from=0&to=4&x={$x}&y={$y}"; $result = @file_get_contents($Baidu_Server); $json = json_decode($result); if($json->error == 0){ $bx = base64_decode($json->x); $by = base64_decode($json->y); $GPS_x = 2 * $x - $bx; $GPS_y = 2 * $y - $by; return $GPS_x.','.$GPS_y;//经度,纬度 }else return $lnglat; }
希望本文所述对大家的php程序设计有所帮助。
php使用正则表达式获取图片url的方法
php截取html字符串及自动补全html标签的方法
php在linux下检测mysql同步状态的方法
将FCKeditor导入PHP+SMARTY的实现方法
php通过Chianz.com获取IP地址与地区的方法
PHP中浮点数计算比较及取整不准确的解决方法
php获取客户端电脑屏幕参数的方法
php实现按照权重随机排序数据的方法
php计划任务之ignore_user_abort函数实现方法
网站防止被刷票的一些思路与方法
分享常见的几种页面静态化的方法
php的ddos攻击解决方法
php使用递归计算文件夹大小
两个php日期控制类实例
PHP集成百度Ueditor 1.4.3
PHP中UNIX时间戳和日期间的转换与计算实例
PHP实现的简单三角形、矩形周长面积计算器分享
利用PHP函数计算中英文字符串长度的方法
PHP根据两点间的经纬度计算距离
百度实时推送api接口应用示例
ThinkPHP整合百度Ueditor图文教程
php生成百度sitemap站点地图类函数实例
php通过隐藏表单控件获取到前两个页面的url
百度地图API应用之获取用户的具体位置
轻信GPS定位找苹果手机反损失“3个苹果”