php根据经纬度计算距离和方向

php根据经纬度计算距离和方向

作者: smarteng ⁄ 时间:2012年09月13日 ⁄ 分类: PHP相关 ⁄  评论:0

现在这个移动终端的天下,

自然而然就有了根据经纬度来计算方向和距离的需求,

LBS就产生了,

可是怎么计算呢 ? 

网上有很多计算距离的,今天我就来个加强版,计算距离和方向。

 

//根据经纬度计算距离和方向

function getRadian($d)

{

return $d * M_PI / 180;

}

function getDistance ($lat1, $lng1, $lat2, $lng2)

{

$lat1 =getRadian($lat1);

$lat2 = getRadian($lat2);

$a = $lat1 - $lat2;

$b = getRadian($lng1) - getRadian($lng2);

$v = 2 * asin(sqrt(pow(sin($a/2),2) +

cos($lat1) * cos($lat2) * pow(sin($b/2),2)));

$v = round(EARTH_RADIUS * $v * 10000) / 10000;

return $v;

}

//根据经纬度计算方向

function getDirection($lat1, $lng1, $lat2, $lng2){

$k1 = $lng2-$lng1;

$k2 = $lat2-$lat1;

if( 0 == $k1){

if($k2>0){

$str="聊友在您的正北方 ";

}

else if( $k2<0){

$str ="聊友在您的正南方 ";

}

else if( $k2 == 0){

$str="聊友正在您的附近 ";

}

}else if( 0 == $k2){

if($k1>0){

$str="聊友在您的正东方 ";

}

else if( $k1<0){

$str="聊友在您的正西方 ";

}

}else{

$k=$k2/$k1;

if($k2>0){

if($k1>0){

$angle = 180*atan($k)/M_PI;

$str="聊友在您的东偏北 $angle 度方向  ";

}else if($k1<0){

$angle = 180*atan(-$k)/M_PI;

$str= "聊友在您的西偏北 $angle 度方向  ";

}

}else if($k2<0){

if($k1<0){

$angle = 180*atan($k)/M_PI;

$str = "聊友在您的西偏南 $angle 度方向  ";

}

else if($k1>0){

$angle = 180*atan($k)/M_PI;

$str="聊友在您的东偏南 $angle 度方向  ";

}

}

}

return $str;

}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值