GPS坐标(经纬度)转换为百度坐标(经纬度)的JAVA方法

声明:此文为转载文章,尊重原创版权,每一分好的代码都来之不易,此方法对于初接触百度地图开发的同学还是不错的。
百度地图API虽说提供了坐标转换的方法,但用过的都知道它只提供了一个js的回调函数,使用起来有很大的局限性,特别要在百度地图上做操作时更不方便。

原文地址:http://bbs.lbsyun.baidu.com/forum.php?mod=viewthread&tid=10923点击打开链接

一、基础知识:

WGS坐标系是国际通用的一种地心坐标系,WGS本身也有多个版本(不赘述了),GCJ-02是国内官方采用的一种坐标系,国内许多坐标系也是基于GCJ-02变种而来的,比如百度坐标系BD-09。就这么简单介绍一下吧,坐标系本身的算法是比较复杂的,需要了解空间地理知识,百度文库里面也有一些坐标纠偏转换算法的相关论文,有兴趣的可以自己去研究。

1、代码:

static double pi = 3.14159265358979324;
static double a = 6378245.0;
static double ee = 0.00669342162296594323;
public final static double x_pi = 3.14159265358979324 * 3000.0 / 180.0;

public static double[] wgs2bd(double lat, double lon) {
       double[] wgs2gcj = wgs2gcj(lat, lon);
       double[] gcj2bd = gcj2bd(wgs2gcj[0], wgs2gcj[1]);
       return gcj2bd;
}

public static double[] gcj2bd(double lat, double lon) {
       double x = lon, y = lat;
       double z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi);
       double theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi);
       double bd_lon = z * Math.cos(theta) + 0.0065;
       double bd_lat = z * Math.sin(theta) + 0.006;
       return new double[] { bd_lat, bd_lon };
}

public static double[] bd2gcj(double lat, double lon) {
       double x = lon - 0.0065, y = lat - 0.006;
       double z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi);
       double theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi);
       double gg_lon = z * Math.cos(theta);
       double gg_lat = z * Math.sin(theta);
       return new double[] { gg_lat, gg_lon };
}

public static double[] wgs2gcj(double lat, double lon) {
       double dLat = transformLat(lon - 105.0, lat - 35.0);
       double dLon = transformLon(lon - 105.0, lat - 35.0);
       double radLat = lat / 180.0 * pi;
       double magic = Math.sin(radLat);
       magic = 1 - ee * magic * magic;
       double sqrtMagic = Math.sqrt(magic);
       dLat = (dLat * 180.0) / ((a * (1 - ee)) / (magic * sqrtMagic) * pi);
       dLon = (dLon * 180.0) / (a / sqrtMagic * Math.cos(radLat) * pi);
       double mgLat = lat + dLat;
       double mgLon = lon + dLon;
       double[] loc = { mgLat, mgLon };
       return loc;
}

private static double transformLat(double lat, double lon) {
       double ret = -100.0 + 2.0 * lat + 3.0 * lon + 0.2 * lon * lon + 0.1 * lat * lon + 0.2 * Math.sqrt(Math.abs(lat));
       ret += (20.0 * Math.sin(6.0 * lat * pi) + 20.0 * Math.sin(2.0 * lat * pi)) * 2.0 / 3.0;
       ret += (20.0 * Math.sin(lon * pi) + 40.0 * Math.sin(lon / 3.0 * pi)) * 2.0 / 3.0;
       ret += (160.0 * Math.sin(lon / 12.0 * pi) + 320 * Math.sin(lon * pi  / 30.0)) * 2.0 / 3.0;
       return ret;
}

private static double transformLon(double lat, double lon) {
       double ret = 300.0 + lat + 2.0 * lon + 0.1 * lat * lat + 0.1 * lat * lon + 0.1 * Math.sqrt(Math.abs(lat));
       ret += (20.0 * Math.sin(6.0 * lat * pi) + 20.0 * Math.sin(2.0 * lat * 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 += (150.0 * Math.sin(lat / 12.0 * pi) + 300.0 * Math.sin(lat / 30.0 * pi)) * 2.0 / 3.0;
       return ret;
}
提供的是JAVA代码,简单注释一下:
pi: 圆周率。
a: 卫星椭球坐标投影到平面地图坐标系的投影因子。
ee: 椭球的偏心率。
x_pi: 圆周率转换量。
transformLat(lat, lon): 转换方法,比较复杂,不必深究了。输入:横纵坐标,输出:转换后的横坐标。
transformLon(lat, lon): 转换方法,同样复杂,自行脑补吧。输入:横纵坐标,输出:转换后的纵坐标。
wgs2gcj(lat, lon): WGS坐标转换为GCJ坐标。
gcj2bd(lat, lon): GCJ坐标转换为百度坐标。


二、百度提供的方法

1.URL方式

http://api.map.baidu.com/ag/coord/convert?from=0&to=4&x=longitude&y=latitude

2.百度地图API

//坐标转换完之后的回调函数
    translateCallback = function (data){
      if(data.status === 0) {
        var marker = new BMap.Marker(data.points[0]);
        bm.addOverlay(marker);
        var label = new BMap.Label("转换后的百度坐标(正确)",{offset:new BMap.Size(20,-10)});
        marker.setLabel(label); //添加百度label
        bm.setCenter(data.points[0]);
      }
    }


三、百度地图点击URL地址显示地图和标注点以及基本信息

http://map.baidu.com/?latlng="+lat+","+lng+"&title="+name+"&content="+remarks+"&autoOpen=true&l				//PC端地图URL格式
http://map.baidu.com/?latlng=30.638846,114.312696&title=我的位置&content=百度奎科大厦&autoOpen=true&l			//PC端地图URL模板


http://api.map.baidu.com/marker?location="+lat+","+lng+"&title="+name+"&content="+remarks+"&output=html			//手机短信地图URL格式
http://api.map.baidu.com/marker?location=30.638846,114.312696&title=我的位置&content=百度奎科大厦&output=html           //手机短信地图URL模板


  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值