十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
經(jīng)緯度就是球坐標(biāo)系,自己百度,百度百科有球坐標(biāo)系轉(zhuǎn)直角坐標(biāo)系的公式,r是地球的半徑(這個(gè)自己百度)。轉(zhuǎn)換后得到兩個(gè)點(diǎn)的坐標(biāo)(x1,y1,z1)(x2,y2,z2),然后兩點(diǎn)距離公式 根號(hào)下((x2-x1)平方+(y2-y1)平方+(z2-z1)平方)
創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比點(diǎn)軍網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式點(diǎn)軍網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋點(diǎn)軍地區(qū)。費(fèi)用合理售后完善,十載實(shí)體公司更值得信賴。
POST一個(gè)位置坐標(biāo)后,根據(jù)位置坐標(biāo)計(jì)算一個(gè)區(qū)域,把區(qū)域里的所有店鋪提取出來 再用距離公式計(jì)算出距離,然后就是簡(jiǎn)單的數(shù)組排序了
這里使用php計(jì)算兩個(gè)坐標(biāo)(經(jīng)度,緯度)之間的距離,返回結(jié)果為米或者千米
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);
}
* */public function getdistanceAction(){ $lng1=117.27; //經(jīng)度1 $lat1=31.86; //緯度1 $lng2=120.19; //經(jīng)度2 $lat2=30.26; //緯度2 $EARTH_RADIUS = 6378137; //地球半徑 $RAD = pi() / 180.0; $radLat1 = $lat1 * $RAD; $radLat2 = $lat2 * $RAD;
不會(huì)算這個(gè)東西,不過看代碼發(fā)現(xiàn)你的代碼里有些問題
第一、兩點(diǎn)間的直線距離平方:$len算完了后面沒有用到,也沒有return, 完全就沒用了
第二、輸入相同的經(jīng)緯度,結(jié)果居然不是0,而且還是個(gè)很大的數(shù),所以應(yīng)該是有問題的
你可以百度一下“php 按經(jīng)緯度算兩點(diǎn)間距離”,有不少現(xiàn)成的代碼
我看這個(gè)介紹的比較詳細(xì),還有代碼,你可以看看
//php 計(jì)算地圖上兩個(gè)坐標(biāo)之間的距離
define('EARTH_RADIUS', 6378.137);//地球半徑,假設(shè)地球是規(guī)則的球體
define('PI', 3.1415926);
/**
* 計(jì)算兩組經(jīng)緯度坐標(biāo) 之間的距離
* params :lat1 緯度1; lng1 經(jīng)度1; lat2 緯度2; lng2 經(jīng)度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);//輸出距離/米