×

php一个经纬度方圆5千米

php一个经纬度方圆5千米(一个经纬度是多少千米)

admin admin 发表于2023-03-23 11:12:11 浏览45 评论0

抢沙发发表评论

本文目录一览:

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会获取用户的经纬度来进行比较。

我做的很久了,代码找不到了。不过我的代码是在网上搜得,代码大概有地球半径什么的数学运算,代码也没多少。就是计算复杂。

你百度搜吧。我忘记在哪找到的了