码迷,mamicode.com
首页 > 其他好文 > 详细

地图开发 火星坐标(GCJ-02)和百度坐标(BD-09)互相转换

时间:2018-04-12 11:37:25      阅读:191      评论:0      收藏:0      [点我收藏+]

标签:火星坐标   百度坐标   高德地图   百度地图   

■ 背景

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

地图开发 火星坐标(GCJ-02)和百度坐标(BD-09)互相转换

标签:火星坐标   百度坐标   高德地图   百度地图   

原文地址:http://blog.51cto.com/13685327/2097292

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!