与我联系

常用地图坐标及相互转换

2018-6-16 一诺 前端工具

一、常用的地图坐标有三种

1、火星坐标(GCJ02)
        火星坐标系,是由中国国家测绘局制订的地理信息系统的坐标系统。并要求在中国使用的地图产品使用的都必须是加密后的坐标,而这套WGS84加密后的坐标就是gcj02。谷歌国内地图、腾讯(搜搜)地图,阿里云地图,高德地图
2、地球坐标(WGS84)
       美国GPS使用的是WGS84的坐标系统,以经纬度的形式来表示地球平面上的某一个位置。GPS、谷歌地图卫星国际上通用的坐标系。设备一般包含GPS芯片或者北斗芯片获取的经纬度为WGS84地理坐标系,最基础的坐标,谷歌地图在非中国地区使用的坐标系 
3、百度坐标(BD09)
       百度坐标系,百度在GCJ02的基础上进行了二次加密,官方解释是为了进一步保护用户隐私,百度地图使用。

二、地图坐标相互转换

1、火星坐标 转换成 百度坐标

/*
    火星坐标 转换成 百度坐标
*/
function bd_encrypt(gg_lon, gg_lat){
    var X_PI = Math.PI * 3000.0 / 180.0;
    var x = gg_lon, y = gg_lat;
    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);
    var bd_lon = z * Math.cos(theta) + 0.0065;
    var bd_lat = z * Math.sin(theta) + 0.006;
    return [ bd_lon, bd_lat ];
}
console.log(bd_encrypt(121.472820, 31.233103)); 
// { bd_lat: 31.22251105448398, bd_lon: 121.44959013138782 }

2、地球坐标 转 火星坐标

/**
    地球坐标 转 火星坐标
*/
//定义一些常量
var x_PI = 3.14159265358979324 * 3000.0 / 180.0;
var PI = 3.1415926535897932384626;
var a = 6378245.0;
var ee = 0.00669342162296594323;
function wgs84togcj02(lng, lat) {
    var dlat = transformlat(lng - 105.0, lat - 35.0);
    var dlng = transformlng(lng - 105.0, lat - 35.0);
    var radlat = lat / 180.0 * PI;
    var magic = Math.sin(radlat);
    magic = 1 - ee * magic * magic;
    var sqrtmagic = Math.sqrt(magic);
    dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * PI);
    dlng = (dlng * 180.0) / (a / sqrtmagic * Math.cos(radlat) * PI);
    var mglat = lat + dlat;
    var mglng = lng + dlng;
    return [mglng, mglat]
}
function transformlat(lng, lat) {
    var ret = -100.0 + 2.0 * lng + 3.0 * lat + 0.2 * lat * lat + 0.1 * lng * lat + 0.2 * Math.sqrt(Math.abs(lng));
    ret += (20.0 * Math.sin(6.0 * lng * PI) + 20.0 * Math.sin(2.0 * lng * PI)) * 2.0 / 3.0;
    ret += (20.0 * Math.sin(lat * PI) + 40.0 * Math.sin(lat / 3.0 * PI)) * 2.0 / 3.0;
    ret += (160.0 * Math.sin(lat / 12.0 * PI) + 320 * Math.sin(lat * PI / 30.0)) * 2.0 / 3.0;
    return ret
}
function transformlng(lng, lat) {
    var ret = 300.0 + lng + 2.0 * lat + 0.1 * lng * lng + 0.1 * lng * lat + 0.1 * Math.sqrt(Math.abs(lng));
    ret += (20.0 * Math.sin(6.0 * lng * PI) + 20.0 * Math.sin(2.0 * lng * PI)) * 2.0 / 3.0;
    ret += (20.0 * Math.sin(lng * PI) + 40.0 * Math.sin(lng / 3.0 * PI)) * 2.0 / 3.0;
    ret += (150.0 * Math.sin(lng / 12.0 * PI) + 300.0 * Math.sin(lng / 30.0 * PI)) * 2.0 / 3.0;
    return ret
}
console.log(wgs84togcj02(121.472820, 31.233103)); 
// [ 31.231164372522493, 121.47734614941194 ]

3、地球坐标 转 百度坐标

/**
    地球坐标 转 百度坐标
*/
var gcj02s = wgs84togcj02(121.472820, 31.233103);
console.log(bd_encrypt(gcj02s[0], gcj02s[1]));
// [ 121.48390063992474, 31.237032597814135 ]


三、直接调用百度地图api进行坐标转换(有次数限制)
    http://lbsyun.baidu.com/index.php?title=webapi/guide/changeposition
    http://api.map.baidu.com/geoconv/v1/?coords=121.443168,31.216148&from=3&to=5&ak=自己申请的key值
    
    http://api.map.baidu.com/geoconv/v1/?coords=121.443168,31.216148&from=3&to=5&ak=C3gNfrM9FE6XBy7jyaiOX6gdg5lOzZm0


四、根据经纬度查看当前坐标地点名称
    http://api.map.baidu.com/lbsapi/getpoint/index.html (坐标反查)

标签: 坐标

分享这篇文章
赞助鼓励:如果觉得内容对您有所帮助,您可以支付宝(左)或微信(右):

声明:如无特殊注明,所有博客文章版权皆属于作者,转载使用时请注明出处。谢谢!

发表评论:

皖ICP备15010162号-1 @2015 勿恨水长东
qq:1614245331 邮箱:13515678147@163.com Powered by
emlog