php计算经纬度距离
1. php计算两个经纬度之间的距离问题,求指导
不会算这个东西,不过看代码发现你的代码里有些问题
第一、两点间的直线距离平方:$len算完了后面没有用到,也没有return, 完全就没用了
第二、输入相同的经纬度,结果居然不是0,而且还是个很大的数,所以应该是有问题的
你可以网络一下“php 按经纬度算两点间距离”,有不少现成的代码
我看这个介绍的比较详细,还有代码,你可以看看
http://blog.csdn.net/vincent_czz/article/details/7963740
2. php两个点经纬度都不知道怎么算距离
希望能帮到你:
/**
*@desc根据两点间的经纬度计算距离
*@paramfloat$lat纬度值
*@paramfloat$lng经度值
*/
functiongetDistance($lat1,$lng1,$lat2,$lng2){
$earthRadius=6367000;//
/*
Convertthesedegreestoradians
toworkwiththeformula
*/
$lat1=($lat1*pi())/180;
$lng1=($lng1*pi())/180;
$lat2=($lat2*pi())/180;
$lng2=($lng2*pi())/180;
/*
Usingthe
Haversineformula
calculatethedistance
*/
$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;
returnround($calculatedDistance);
}
3. 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);
}
4. 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);//输出距离/米
5. php 计算某个经纬度的周围某段距离的正方形的四个点
后盾网哪里有详细解释的,而且一对一培训,视频质量也很好的,不炒概念,边教学边练习,质量高
6. 如何使用php计算出两个经纬度之间的距离
* */public function getdistanceAction(){ $lng1=117.27; //经度1 $lat1=31.86; //纬度1 $lng2=120.19; //经度2 $lat2=30.26; //纬度2 $EARTH_RADIUS = 6378137; //地球半径 $RAD = pi() / 180.0; $radLat1 = $lat1 * $RAD; $radLat2 = $lat2 * $RAD;
7. 怎样根据具体地址计算经纬度 php
首先将该点的经纬度(l1,b1)利用高斯正算计算出在某个坐标系下的投影坐标(x1,y1)。
(x1,y1)
=
gk(l1,b1)
gk()代表高斯克吕格投影
然后根据距离和方位角s,alpha,计算出另一点的坐标(x2,y2)
x2
=
x1+
s*cos(alpha)
y2
=
y2+
s*sin(alpha)
最后利用高斯反算即可计算出另一点的经纬度(l2,b2)
8. php怎么计算两个经纬度之间的距离
经纬度就是球坐标系,自己网络,网络有球坐标系转直角坐标系的公式,r是地球的半径(这个自己网络)。转换后得到两个点的坐标(x1,y1,z1)(x2,y2,z2),然后两点距离公式 根号下((x2-x1)平方+(y2-y1)平方+(z2-z1)平方)