java根据经纬度计算距离_java经纬度转换xy坐标公式

java根据经纬度计算距离_java经纬度转换xy坐标公式反余弦计算方式:privatestaticfinaldoubleEARTH_RADIUS=6371000;//平均半径,单位:m;不是赤道半径。赤道为6378左右publicstaticdoublegetDistance(Doublelat1,Doublelng1,Doublelat2,Doublelng2){//经纬度(角度)转弧度。弧度用作参数,以调用Math…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

反余弦计算方式:

private static final double EARTH_RADIUS = 6371000; // 平均半径,单位:m;不是赤道半径。赤道为6378左右

public static double getDistance(Double lat1,Double lng1,Double lat2,Double lng2) {

// 经纬度(角度)转弧度。弧度用作参数,以调用Math.cos和Math.sin

double radiansAX = Math.toRadians(lng1); // A经弧度

double radiansAY = Math.toRadians(lat1); // A纬弧度

double radiansBX = Math.toRadians(lng2); // B经弧度

double radiansBY = Math.toRadians(lat2); // B纬弧度

// 公式中“cosβ1cosβ2cos(α1-α2)+sinβ1sinβ2”的部分,得到∠AOB的cos值

double cos = Math.cos(radiansAY) * Math.cos(radiansBY) * Math.cos(radiansAX – radiansBX)

+ Math.sin(radiansAY) * Math.sin(radiansBY);

// System.out.println(“cos = ” + cos); // 值域[-1,1]

double acos = Math.acos(cos); // 反余弦值

// System.out.println(“acos = ” + acos); // 值域[0,π]

// System.out.println(“∠AOB = ” + Math.toDegrees(acos)); // 球心角 值域[0,180]

return EARTH_RADIUS * acos; // 最终结果

}

利用第三方jar包计算:

引依赖:

org.gavaghan

geodesy

1.1.3

代码:

public static double getDistanceMeter(GlobalCoordinates gpsFrom, GlobalCoordinates gpsTo, Ellipsoid ellipsoid)

{

//创建GeodeticCalculator,调用计算方法,传入坐标系、经纬度用于计算距离

GeodeticCurve geoCurve = new GeodeticCalculator().calculateGeodeticCurve(ellipsoid, gpsFrom, gpsTo);

return geoCurve.getEllipsoidalDistance();

}

计算结果对比:

public static void main(String[] args) {

//121.717594,31.12055 121.817629,31.090867

// double distance = getDistance(31.12055, 121.717594,31.090867, 121.817629);

double distance = getDistance(29.090295, 106.486654,29.615467, 106.581515);

System.out.println(“距离” + distance + “米”);

GlobalCoordinates source = new GlobalCoordinates(29.090295, 106.486654);

GlobalCoordinates target = new GlobalCoordinates(29.615467, 106.581515);

double meter1 = getDistanceMeter(source, target, Ellipsoid.Sphere);

double meter2 = getDistanceMeter(source, target, Ellipsoid.WGS84);

System.out.println(“Sphere坐标系计算结果:”+meter1 + “米”);

System.out.println(“WGS84坐标系计算结果:”+meter2 + “米”);

}

d8c2a8f140c3dba5ef036f67fcf6f0a2.png

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/190186.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • allow_url_fopen与安全以及PHP libcurl

    allow_url_fopen与安全以及PHP libcurl  allow_url_fopen=ON常常会给服务器和管理员带来麻烦,但是经常性(至少我这样认为)的我们需要远程读取某个东西,如果设置allow_url_fopen=OFF将其关闭,我们就没有办法远程读取。  幸好我们有一个很好的PHP模块–curl。下面我就以一个例子说说我用curl远程读取的方法:  第一,allow_url_fopen=ON的情况下:

    2022年7月21日
    10
  • MySQL 如何实现递归查询?「建议收藏」

    MySQL 如何实现递归查询?「建议收藏」点击上方IT牧场,选择置顶或者星标技术干货每日送达!前言最近在做的业务场景涉及到了数据库的递归查询。我们公司用的Oracle,众所周知,Oracle自带有递归查询的功能,所以…

    2022年6月16日
    211
  • HikariPool-1 – Connection is not available, request timed out after 30000ms.

    HikariPool-1 – Connection is not available, request timed out after 30000ms.HikariPool是号称史上最快的数据库连接池,而且目前来看确实是这样的,SpringBoot2.0也已经采用HikariCP作为默认连接池配置.近期项目也将druid切成了HikariPool,但HikariPool仍然不够稳定,经常出现获取不到数据库连接,连接数不够的问题尝试修改HikariPool连接池配置,增大最大连接数,MaximumPoolSize由30改为100…

    2022年6月23日
    28
  • vue笔记(2)vue中使用ajax

    vue笔记(1):https://blog.csdn.net/qq_43537987/article/details/93402865Vue中利用vue-resource发起Ajax请求除了vue-resource之外,还可以使用axios的第三方包实现实现数据的请求参考网址:https://www.runoob.com/vue2/vuejs-ajax.htmlhttp…

    2022年4月9日
    65
  • 宽字节注入原理分析[通俗易懂]

    宽字节注入原理分析[通俗易懂]什么是宽字节?如果一个字符的大小是一个字节的,称为窄字节;如果一个字符的大小是两个字节的,成为宽字节。像GB2312、GBK、GB18030、BIG5、Shift_JIS等这些编码都是常说的宽字节,也就是只有两字节英文默认占一个字节,中文占两个字节什么是宽字节注入?原理:宽字节注入是利用了mysql的一个特性,即mysql在使用GBK编码时,在url解码时会认为两个字符是一个汉字(前一个ASCII码要大于128,才表示到汉字的范围)通常情况下,一个utf-8编码的汉子占用3个字节,一个GBK编

    2022年10月15日
    0
  • 美化包软件_手机主题美化软件

    美化包软件_手机主题美化软件前言在我们进行自动化测试的时候,用例往往是成百上千,执行的时间是几十分钟或者是小时级别。有时,我们在调试那么多用例的时候,不知道执行到什么程度了,而pytest-sugar插件能很好解决我们的痛点。

    2022年7月31日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号