- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Java计算两个坐标之间的距离
背景:
在做项?的时候需要做?机端页?,需要计算两个坐标的距离,由于之前没有接触过这样的计算,于是就找上度娘帮忙,顺便记录下来
1、添加JTS依赖
JTS是加拿?的 Vivid Solutions公司做的?套开放源码的 Java API。它提供了?套空间数据操作的核?算法。为在兼容OGC标准的空间对象模型中进?基础的?何操作提供2D空间谓词API。!--
JTS是加拿?的 Vivid Solutions公司做的?套开放源码的 Java API。它提供了?套空间数据操作的核?算法。为在兼容OGC标准的空间对象模型中进?基础的?何操作提供2D空间谓词API。
!--空间地理坐标算法--
dependency
groupIdcom.vividsolutions/groupId
artifactIdjts-core/artifactId
version1.14.0/version
/dependency
2、坐标系转换
WGS-84:是国际标准,GPS坐标(Google Earth使?、或者GPS模块) GCJ-02:中国坐标偏移标准,Google Map、?德、腾讯使?BD-09:百度坐标偏移标准,Baidu Map使?
WGS-84:是国际标准,GPS坐标(Google Earth使?、或者GPS模块) GCJ-02:中国坐标偏移标准,Google Map、?德、腾讯使?
BD-09:百度坐标偏移标准,Baidu Map使?
/**
* @Description 坐标标转换?具类
*/
public class CoordinateUtil {
/**
* pi
*/
public final static double pi = 3.1415926535897932384626;
/**
* a
*/
public final static double a = 6378245.0;
/**
* ee
*/
public final static double ee = 0.00669342162296594323;
/**
@Description WGS84 to ?星坐标系 (GCJ-02)
@param lon
@param lat
@return
*/
public static double[] wgs84_To_Gcj02(double lon, double lat) { if (outOfChina(lat, lon)) {
return null;
}
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[] { mgLon, mgLat };
}
/**
@Description ?星坐标系 (GCJ-02) to WGS84
@param lon
@param lat
@return
*/
public static double[] gcj02_To_Wgs84(double lon, double lat) { double[] gps = transform(lat, lon);
double lontitude = lon * 2 - gps[1]; double latitude = lat * 2 - gps[0];
return new double[] { lontitude, latitude };
}
/**
@Description ?星坐标系 (GCJ-02) to 百度坐标系 (BD-09)
@param gg_lon
@param gg_lat
@return
*/
public static double[] gcj02_To_Bd09(double gg_lon, double gg_lat) { double x
原创力文档


文档评论(0)