GPS坐标转换成百度坐标及方法共享.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
GPS坐标转换成百度坐标及方法共享

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

文档评论(0)

qiwqpu54 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档