地图经纬度

/**

* 中国正常GCJ02坐标---->百度地图BD09坐标

* 腾讯地图用的也是GCJ02坐标

* @param double $lat 纬度

* @param double $lng 经度

*/

function Convert_GCJ02_To_BD09($lat,$lng){

$x_pi = 3.14159265358979324 * 3000.0 / 180.0;

$x = $lng;

$y = $lat;

$z =sqrt($x * $x + $y * $y) + 0.00002 * sin($y * $x_pi);

$theta = atan2($y, $x) + 0.000003 * cos($x * $x_pi);

$lng = $z * cos($theta) + 0.0065;

$lat = $z * sin($theta) + 0.006;

return array('lng'=>$lng,'lat'=>$lat);

}

/**

* 百度地图BD09坐标---->中国正常GCJ02坐标

* 腾讯地图用的也是GCJ02坐标

* @param double $lat 纬度

* @param double $lng 经度

* @return array();

*/

function Convert_BD09_To_GCJ02($lat,$lng){

$x_pi = 3.14159265358979324 * 3000.0 / 180.0;

$x = $lng - 0.0065;

$y = $lat - 0.006;

$z = sqrt($x * $x + $y * $y) - 0.00002 * sin($y * $x_pi);

$theta = atan2($y, $x) - 0.000003 * cos($x * $x_pi);

$lng = $z * cos($theta);

$lat = $z * sin($theta);

return array('lng'=>$lng,'lat'=>$lat);

}

/**

*  @desc 根据两点间的经纬度计算距离

*  @param float $lat 纬度值

*  @param float $lng 经度值

*/

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

{

$earthRadius = 6367000; //approximate radius of earth in meters

$lat1 = ($lat1 * pi() ) / 180;

$lng1 = ($lng1 * pi() ) / 180;

$lat2 = ($lat2 * pi() ) / 180;

$lng2 = ($lng2 * pi() ) / 180;

$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;

return round($calculatedDistance);

}

你可能感兴趣的:(地图经纬度)