本文目录一览:
- 1、php经纬度之间的距离怎么算单位是公里
- 2、php怎么计算两个经纬度之间的距离
- 3、已知一点坐标(经纬度),如何判断其方圆500米的范围?
- 4、知道一个经纬度如何算出以此为圆点的,半径为5KM的经纬度范围?
- 5、php 计算经纬度之间相差多少公里
- 6、php 怎么根据一地的经纬度计算多个地方之间的距离
php经纬度之间的距离怎么算单位是公里
这里使用php计算两个坐标(经度,纬度)之间的距离,返回结果为米或者千米
function distance($lat1, $lng1, $lat2, $lng2, $miles = true)
{
$pi80 = M_PI / 180;
$lat1 *= $pi80;
$lng1 *= $pi80;
$lat2 *= $pi80;
$lng2 *= $pi80;
$r = 6372.797; // mean radius of Earth in km
$dlat = $lat2 - $lat1;
$dlng = $lng2 - $lng1;
$a = sin($dlat/2)*sin($dlat/2)+cos($lat1)*cos($lat2)*sin($dlng/2)*sin($dlng/2);
$c = 2 * atan2(sqrt($a), sqrt(1 - $a));
$km = $r * $c;
return ($miles ? ($km * 0.621371192) : $km);
}
php怎么计算两个经纬度之间的距离
经纬度就是球坐标系,自己百度,百度百科有球坐标系转直角坐标系的公式,r是地球的半径(这个自己百度)。转换后得到两个点的坐标(x1,y1,z1)(x2,y2,z2),然后两点距离公式 根号下((x2-x1)平方+(y2-y1)平方+(z2-z1)平方)-php一个经纬度方圆5千米
已知一点坐标(经纬度),如何判断其方圆500米的范围?
你可以先算出该点周围的矩形的四个点,然后使用经纬度去直接匹配数据库中的记录;如下图
参考wiki百科上的一些球面计算公式:
Great-circle distance
Haversine formula
假设已知点的经纬度分别为$lng, $lat
先实现经度范围的查询,
在haversin公式中令φ1 = φ2,可得:
用PHP进行计算,就是:
然后是纬度范围的查询,
在haversin公式中令 Δλ = 0,可得
在PHP中进行计算,就是:
最后,就可以得出四个点的坐标:
left-top : (lat + dlat, lng – dlng)
right-top : (lat + dlat, lng + dlng)
left-bottom : (lat – dlat, lng – dlng)
right-bottom: (lat – dlat, lng + dlng)
我把以上方法写成了一个函数,综合起来就是:
在lat和lng上建立一个联合索引后,使用此项查询,每条记录的查询消耗平均为0.8毫秒,啧啧,效率妥妥的!
知道一个经纬度如何算出以此为圆点的,半径为5KM的经纬度范围?
因为地理上,不同维度上5千米所距离所跨越的纬度不同,所以,较简单的办法可能是找一幅包含已知点,标有经纬度的地图,如万分之一地图,按比例以5千米为半径画圆来确定覆盖范围的经纬度;
若希望以圆方程来表示,则因上述原因,能适于不同纬度的方程可能较难推导.
php 计算经纬度之间相差多少公里
//php 计算地图上两个坐标之间的距离
define('EARTH_RADIUS', 6378.137);//地球半径,假设地球是规则的球体
define('PI', 3.1415926);
/**
* 计算两组经纬度坐标 之间的距离
* params :lat1 纬度1; lng1 经度1; lat2 纬度2; lng2 经度2; len_type (1:m or 2:km);
* return m or km
*/
function GetDistance($lat1, $lng1, $lat2, $lng2, $len_type = 1, $decimal = 2)
{
$radLat1 = $lat1 * PI ()/ 180.0; //PI()圆周率
$radLat2 = $lat2 * PI() / 180.0;
$a = $radLat1 - $radLat2;
$b = ($lng1 * PI() / 180.0) - ($lng2 * PI() / 180.0);
$s = 2 * asin(sqrt(pow(sin($a/2),2) + cos($radLat1) * cos($radLat2) * pow(sin($b/2),2)));
$s = $s * EARTH_RADIUS;
$s = round($s * 1000);
if ($len_type -- 1)
{
$s /= 1000;
}
return round($s, $decimal);
}
echo GetDistance(39.908156,116.4767, 39.908452,116.450479, 1);//输出距离/米
php 怎么根据一地的经纬度计算多个地方之间的距离
你需要知道你已经得到的经纬度是谷歌的还是百度的。
我之前做过一个团购的搜附近的美食计算距离,数据库存着每个店铺的经纬度,APP会获取用户的经纬度来进行比较。
我做的很久了,代码找不到了。不过我的代码是在网上搜得,代码大概有地球半径什么的数学运算,代码也没多少。就是计算复杂。
你百度搜吧。我忘记在哪找到的了