美文网首页
地图经纬度

地图经纬度

作者: 上善若水_900e | 来源:发表于2017-09-11 08:20 被阅读0次

    /**

    * 中国正常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);

    }

    相关文章

      网友评论

          本文标题:地图经纬度

          本文链接:https://www.haomeiwen.com/subject/lkexsxtx.html