地图相关-百度-高德相互转换

  1. 国际坐标系 WGS-84:地心坐标系,国际通用。应用:Googole Map
  2. 火星坐标系 GCJ-02:由中国×××(G表示Guojia国家,C表示Cehui测绘,J表示Ju局)制订的地理信息系统的坐标系统。应用:高德地图
  3. 百度坐标系 BD-09:在GCJ-02的基础上二次偏移。应用:百度地图

GCJ-02和BD-09互相转换 (js)

// 高德地图坐标系(火星坐标GCJ-02) -> 百度地图坐标系(百度坐标BD-09)
// 参数形式为"lng,lat"
// 返回字符串"lng,lat"
function gcj2bdString(value, mapType) {
    if (mapType == BAIDU) {
        var x_pi = 3.14159265358979324 * 3000.0 / 180.0;
        var ll = value.split(",");
        var x = ll[0], y = ll[1];
        var z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi);
        var theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi);
        return (z * Math.cos(theta) + 0.0065) + ',' + (z * Math.sin(theta) + 0.006);
    } else if (mapType == GAODE) {
        return value;
    }
}

// 百度地图坐标系(百度坐标BD-09) -> 高德地图坐标系(火星坐标GCJ-02)
// 参数形式为"lng,lat"
// 返回字符串"lng,lat"
function bd2gcjString(value, mapType) {
    if (mapType == BAIDU) {
        var x_pi = 3.14159265358979324 * 3000.0 / 180.0;
        var ll = value.split(",");
        var x = ll[0] - 0.0065, y = ll[1] - 0.006;
        var z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi);
        var theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi);
        return (z * Math.cos(theta)) + ',' + (z * Math.sin(theta));
    } else if (mapType == GAODE) {
        return value;
    }
}

百度转高德


public static void bd_decrypt(double bd_lat, double bd_lon)
{
    double x = bd_lon - 0.0065, y = bd_lat - 0.006;
    double z = sqrt(x * x + y * y) - 0.00002 * sin(y * x_pi);
    double theta = atan2(y, x) - 0.000003 * cos(x * x_pi);
    double gg_lon = z * cos(theta);
    double gg_lat = z * sin(theta);

    BigDecimal lat = new BigDecimal(gg_lat);
    BigDecimal lon = new BigDecimal(gg_lon);
    System.out.println(bd_lat+","+bd_lon);
    System.out.println(gg_lat+","+gg_lon);
    System.out.println(lat.setScale(6,   BigDecimal.ROUND_HALF_DOWN)+","+lon.setScale(6,   
                       BigDecimal.ROUND_HALF_DOWN));
}

猜你喜欢

转载自blog.csdn.net/wcuuchina/article/details/87873004