- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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) {
? ??
您可能关注的文档
最近下载
- 八年级上名著《红岩》第10章(讲练测).docx VIP
- 表面处理技术在高端装备制造中的应用与挑战报告2025.docx
- 汪曾祺《钓鱼大夫》阅读答案试题解析理解 .pdf VIP
- 家庭反暴强制报告制度及服务流程.docx VIP
- 聚醚多元醇企业标准.pdf VIP
- 八年级上名著《红岩》第11章(讲练测).docx VIP
- T_CIATCM 093—2020_基层医疗卫生机构中医诊疗区(中医馆)团体标准远程会诊系统建设指南中国中医药信息学会.pdf VIP
- 八年级上名著《红岩》第12章(讲练测).docx VIP
- 2025国投生物制造创新研究院有限公司招聘(31人)考试备考试题及答案解析.docx VIP
- 边坡位移监测记录表.xlsx VIP
文档评论(0)