常用地图经纬度转换,以及遇到的问题和解决方式
坐标系分类
第一种分类1、GPS,WGS-84,原始坐标体系。一般用国际标准的GPS记录仪记录下来的坐标,都是GPS的坐标。很可惜,在中国,任何一个地图产品都不允许使用GPS坐标,据说是为了保密。2、GCJ-02,国测局02年发布的坐标体系。又称“火星坐标”。在中国,必须至少使用GCJ-02的坐标体系。比如谷歌,腾讯,高德都在用这个坐标体系。GCJ-02也是国内最广泛使用的坐标体系。3、其他坐标体系。一般都是由GCJ-02进过偏移算法得到的。这种体系就根据每个公司的不同,坐标体系都不一样了。比如,百度和搜狗就使用自己的坐标体系,与其他坐标体系不兼容。
第二种分类首先明白,所有坐标体系的原点,都是非洲。
1、经纬度。这个是球面坐标,对于北京来说,就是(116.38817139.935961)这样的坐标。比如腾讯、高德、百度都是这样的经纬度坐标。谷歌是经纬度顺序写反的经纬度坐标。
如果是度分秒坐标,需要进行转换,才能得到这样的经纬度坐标。详见坐标转换。
2、墨卡托坐标。平面坐标,相当于是直线距离,数字一般都比较大,像这样的。(215362.0002133333599526.00034912192)
墨卡托坐标,主要用于程序的后台计算。直线距离嘛,加加减减几乎计算方便。
搜狗地图API就是直接使用的墨卡托坐标。
经纬度转换工具类
static double pi = 3.14159265358979324;
static double a = 6378245.0;
static double ee = 0.00669342162296594323;
public final static double x_pi = pi * 3000.0 / 180.0;/**
* 高德经纬度转百度经纬度
*/
public static double[] gcj2bd(double lat, double lon) {double z = Math.sqrt(lon * lon + lat * lat) + 0.00002 * Math.sin(lat * x_pi);
double theta = Math.atan2(lat, lon) + 0.000003 * Math.cos(lon * 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;
return new double[]{ mgLat, mgLon };
}/**
* 高德转到GPS
*/
public static double[] gcj2wgc(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 lontitude = lon * 2 - mgLon;
double latitude = lat * 2 - mgLat;
return new double[]{latitude, lontitude};
}/**
* 国标转百度
*/
public static double[] wgs2bd(double lat, double lon) {double[] wgs2gcj = wgs2gcj(lat, lon);
return gcj2bd(wgs2gcj[0], wgs2gcj[1]);
}/**
* 经纬度转换
*/
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 = getRet(lat, lon, ret);
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 getRet(double lat, double lon, double ret) {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;
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 = getRet(lat, lat, ret);
ret += (150.0 * Math.sin(lat / 12.0 * pi) + 300.0 * Math.sin(lat / 30.0 * pi)) * 2.0 / 3.0;
return ret;
}
PS:因为经纬度的获取是依靠卫星的,所以屋内无法获取经纬度。并且哪怕你站在一个点移动,经纬度的获取也是有飘忽的,允许误差大概在10米以内即可。
软硬件结合时要提前沟通好使用的经纬度分类。比如软件使用的是高德坐标,而硬件获取的则是其他坐标系或者使用的安卓原生坐标,尤其是后者转换后仍旧不属于任何一种坐标,所以尽量避免硬件传输安卓原生坐标,可以通过相关地图,比如高德的sdk进行转换。
创作不易,如果这篇文章对你有用,请点个赞谢谢♪(・ω・)ノ!
常用地图经纬度转换,以及遇到的问题和解决方式相关推荐
- python 地图偏移_python 地图经纬度转换、纠偏的实例代码 百度地图经纬度web纠偏怎么用...
天地图的经纬度 经过纠偏了么 给个例子证明下 如何用python实现百度地图墨卡托坐标跟经纬度坐标互转 麦哲伦机器: 系统设置 地图单位 自定义坐标系 横向墨卡托 原点纬度0 原点经度126(通化) ...
- python 地图偏移_python 地图经纬度转换、纠偏的实例代码
python 地图经纬度转换.纠偏的代码如下所示: # -*- coding: utf-8 -*- import json import urllib import math x_pi = 3.141 ...
- java常用地图坐标系转换工具类,支持谷歌,腾讯,百度等主流的地理坐标转换
package com.shen.springboot.redis.util;import java.util.ArrayList; import java.util.HashMap; import ...
- android 经纬度 转换成地址,Android 百度地图经纬度转换成地址
1.地理编码查询接口是单列模式的,我们需要调用让它自己实例化 // 在OnCreate方法里创建地理编码检索实例 GeoCoder geoCoder = GeoCoder.newInstance(); ...
- 百度地图经纬度转换腾讯地图经纬度
百度地图经纬度转腾讯地图经纬度 function bMapTransQQMap(lng,lat){ let x_pi = 3.14159265358979324 * 3000.0 / ...
- 百度地图与腾讯/高德地图经纬度转换
//将腾讯/高德地图经纬度转换为百度地图经纬度 //将腾讯/高德地图经纬度转换为百度地图经纬度 function qqMapTransBMap(lng, lat) {let x_pi = 3.1415 ...
- Android开发之百度地图经纬度转换地址(以及获取详细地址的方法自测成功)
方法一: 直接粘贴代码 GeoCoder mSearch = GeoCoder.newInstance();mSearch.setOnGetGeoCodeResultListener(new OnGe ...
- js处理腾讯地图经纬度转换百度地图经纬度
}) /** * 坐标转换,腾讯地图转换成百度地图坐标 * lng 腾讯经度(pointy) * lat 腾讯纬度(pointx ...
- python 地图偏移_python 地图经纬度转换、纠偏
# -*- coding: utf-8 -*- import json import urllib import math x_pi = 3.14159265358979324 * 3000.0 / ...
- USERKEY_PLAT_NOMATCH——高德地图经纬度转换API使用报错
根据不同的API需求,为应用添加相应的key 高德地图错误信息表--https://lbs.amap.com/api/wx/reference/errorcode/ 高德开放平台地址--https:/ ...
最新文章
- 超详细的 Redis Cluster 官方集群搭建指南,适用于 redis 5.x, 6.x
- Understanding Stock Types in SAP EWM
- 用脑电波玩游戏,这款VR体验逆天了
- Eclipse中CVS版本管理
- php soap对象数组,nusoap传递数组对象
- VTK:图像亮度用法实战
- iOS--viewController
- 终于要跟大家见面了,Flink 面试指南
- 利用SMS实现资产管理
- java求职英文简历范本2篇_Java英文简历范文
- 51单片机的汇编语言
- python手写字体程序,Python3生成手写体数字方法
- 武器与战术:对聚变时代太空舰队的构想
- x86服务器能装64位系统吗,x86处理器能装64位系统吗_64位系统装32位的可以么
- IAM统一身份认证服务
- 前端工程师面试问题归纳(一、问答类html/css/js基础)
- No7. 字符串匹配
- mysql引擎怎么选
- python开发ps插件_python +ps 三方面库整理
- 如何在谷歌地球上画路线或者运动轨迹?根据纬经高信息在谷歌地球Google earth中画运动轨迹,首先将Excel文件纬经高信息转换为.csv文件,再转换为.kml文件,最终在谷歌地球中显示。
热门文章
- JAVA-JDK环境变量配置
- 0-简单工厂模式类图
- 关于Mac下载brew报curl: (7) Failed to connect to raw.githubusercontent.com port 443: Connection refused
- fastboot 刷入第三方 Recovery——Android 安装 Xposed 框架那点事
- 我的世界观【文津图书奖获奖作品】
- 2020年系统集成项目管理工程师课教程
- python day 105
- 《Photoshop Lightroom4 经典教程》目录—导读
- 关于Matlab的MEX技术 10分钟教会你简单的matlab和C/C++混合编程(mex文件)
- 解决print spooler打印服务自动停止的过程记录