


全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
WGS坐标系是国际通用的一种地心坐标系,WGS本身也有多个版本(不赘述了),GCJ-02是国内官方采用的一种坐标系,国内许多坐标系也是基于GCJ-02变种而来的,比如百度坐标系BD-09。就这么简单介绍一下吧,坐标系本身的算法是比较复杂的,需要了解空间地理知识,百度文库里面也有一些坐标纠偏转换算法的相关论文,有兴趣的可以自己去研究。上代码:1. static double pi = 3.14159265358979324;2. static double a = 6378245.0;3. static double ee = 0.00669342162296594323;4. public final static double x_pi = 3.14159265358979324 * 3000.0 / 180.0;5.6. public static double wgs2bd(double lat, double lon) 7. double wgs2gcj = wgs2gcj(lat, lon);8. double gcj2bd = gcj2bd(wgs2gcj0, wgs2gcj1);9. return gcj2bd;10. 11.12. public static double gcj2bd(double lat, double lon) 13. double x = lon, y = lat;14. double z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi);15. double theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi);16. double bd_lon = z * Math.cos(theta) + 0.0065;17. double bd_lat = z * Math.sin(theta) + 0.006;18. return new double bd_lat, bd_lon ;19. 20.21. public static double bd2gcj(double lat, double lon) 22. double x = lon - 0.0065, y = lat - 0.006;23. double z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi);24. double theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi);25. double gg_lon = z * Math.cos(theta);26. double gg_lat = z * Math.sin(theta);27. return new double gg_lat, gg_lon ;28. 29.30. public static double wgs2gcj(double lat, double lon) 31. double dLat = transformLat(lon - 105.0, lat - 35.0);32. double dLon = transformLon(lon - 105.0, lat - 35.0);33. double radLat = lat / 180.0 * pi;34. double magic = Math.sin(radLat);35. magic = 1 - ee * magic * magic;36. double sqrtMagic = Math.sqrt(magic);37. dLat = (dLat * 180.0) / (a * (1 - ee) / (magic * sqrtMagic) * pi);38. dLon = (dLon * 180.0) / (a / sqrtMagic * Math.cos(radLat) * pi);39. double mgLat = lat + dLat;40. double mgLon = lon + dLon;41. double loc = mgLat, mgLon ;42. return loc;43. 44.45. private static double transformLat(double lat, double lon) 46. 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);47. ret += (20.0 * Math.sin(6.0 * lat * pi) + 20.0 * Math.sin(2.0 * lat * pi) * 2.0 / 3.0;48. ret += (20.0 * Math.sin(lon * pi) + 40.0 * Math.sin(lon / 3.0 * pi) * 2.0 / 3.0;49. ret += (160.0 * Math.sin(lon / 12.0 * pi) + 320 * Math.sin(lon * pi/ 30.0) * 2.0 / 3.0;50. return ret;51. 52.53. private static double transformLon(double lat, double lon) 54. double ret = 300.0 + lat + 2.0 * lon + 0.1 * lat * lat + 0.1 * lat * lon + 0.1 * Math.sqrt(Math.abs(lat);55. ret += (20.0 * Math.sin(6.0 * lat * pi) + 20.0 * Math.sin(2.0 * lat * pi) * 2.0 / 3.0;56. ret += (20.0 * Math.sin(lat * pi) + 40.0 * Math.sin(lat / 3.0 * pi) * 2.0 / 3.0;57. ret += (150.0 * Math.sin(lat / 12.0 * pi) + 300.0 * Math.sin(lat / 30.0 * pi) * 2.0 / 3.0;58. return ret;59. 复制代码我提供的是JAVA代码,简单注释一下:pi: 圆周率。a: 卫星椭球坐标投影到平面地图坐标系的投影因子。ee: 椭球的偏心率。x_pi: 圆周率转换量。transformLat(lat, lon): 转换方法,比较
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025能源集团所属铁法能源公司招聘45人笔试参考题库附带答案详解
- 2025湖南高速养护工程有限公司招聘劳务派遣员工55人(长期)笔试参考题库附带答案详解
- 卸车人员安全培训记录课件
- 2025广东韶关市曲江区国有资产投资经营有限公司招聘驾驶员1人笔试参考题库附带答案详解
- 2025年江西省水投江河信息技术有限公司社会招聘2人笔试参考题库附带答案详解
- 2025年山西大地环境投资控股有限公司所属企业社会招聘79人笔试参考题库附带答案详解
- 2025年中国石油集团昆仑资本有限公司公开招聘正式启动笔试参考题库附带答案详解
- 2025年中国出口信用保险公司浙江分公司校园招聘1人笔试参考题库附带答案详解
- 2025国家电投福建公司招聘1人(总经理)笔试参考题库附带答案详解
- 2025四川华芯鼎泰精密电子有限公司招聘产品设计工程师等岗位34人笔试参考题库附带答案详解
- YC/Z 550-2016卷烟制造过程质量风险评估指南
- 工程水文第3章课件
- GB/T 4032-2013具有摆轮游丝振荡系统的精密手表
- GB/T 34875-2017离心泵和转子泵用轴封系统
- GB/T 21063.4-2007政务信息资源目录体系第4部分:政务信息资源分类
- GA/T 1081-2020安全防范系统维护保养规范
- 02药物不良反应adr课件
- 施工项目成本管理课件
- 文物建筑保护修缮专项方案
- 营销与2008欧锦赛ktv渠道方案
- 故障录波器课件
评论
0/150
提交评论