标签:pre 不用 范围 cti 根据 转换 param 版本 解释
/** *求两个已知经纬度之间的距离,单位为米 *@param lng1,lng2 经度 *@param lat1,lat2 纬度 *@return float 距离,单位米 **/ function getDistance($lng1,$lat1,$lng2,$lat2){ //将角度转为狐度 $radLat1=deg2rad($lat1);//deg2rad()函数将角度转换为弧度 $radLat2=deg2rad($lat2); $radLng1=deg2rad($lng1); $radLng2=deg2rad($lng2); $a=$radLat1-$radLat2; $b=$radLng1-$radLng2; $s=2*asin(sqrt(pow(sin($a/2),2)+cos($radLat1)*cos($radLat2)*pow(sin($b/2),2)))*6378.137*1000; return $s; } sql版:这里x是经度,Y是纬度 SELECT FORMAT(((6370996.81)*ACOS(COS( coordy2 *PI()/180) * COS({$y}*PI()/180) * COS(( coordx2 *PI()/180)-({$x}*PI()/180)) + SIN( coordy2 *PI()/180)*SIN( {$y} *PI()/180)))/1000,2) as distance
解释一下下
这里是两个版本,一个是封装的函数 一个是sql语句
在sql版本中,$x,$y因为是变量所以加了{},正式写的时候是不用加的
例如
因为这里除以了1000,并且保留2为小数,如图:
所以最后算下来是公里!如果想要米数,那么就把/1000去掉
例如:
下边的例子调用:
标签:pre 不用 范围 cti 根据 转换 param 版本 解释
原文地址:http://www.cnblogs.com/hopelooking/p/7495065.html