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)
上一篇 2026年2月25日 下午7:43
下一篇 2026年2月25日 下午8:15


相关推荐

  • 申请软件著作权步骤_著作权包括哪些

    申请软件著作权步骤_著作权包括哪些今年八月底版权中心系统升级,新系统相对好用一些,至少不用再拿IE访问了,但是多了一项实名认证。下面介绍新系统的操作流程。目录注册、登录和实名认证注册登录实名认证软件登记申请申请表填写鉴别材料身份证明文件权利归属证明文件其他材料提交材料变更登记注册、登录和实名认证首先访问版权中心系统:https://register.ccopyright.com.cn/login.html,如果老系统有账号直接登录即可,没有的话需要注册。注册点击注册按钮进入注册。根据实际情况选择个人或单位,每个个人或单位只能在

    2026年2月15日
    4
  • 织梦首页怎么调用栏目下的文章列表

    织梦首页怎么调用栏目下的文章列表

    2021年9月21日
    39
  • 解决跨域问题的8种方案(最新最全)

    解决跨域问题的8种方案(最新最全)转自PheonixHkbxoic的《前端解决跨域问题的8种方案(最新最全)》原址:https://www.cnblogs.com/PheonixHkbxoic/p/5760838.html1.同源策略如下:URL 说明 是否允许通信 http://www.a.com/a.js http://www.a.com/b.js 同一域名下 允许 …

    2025年6月9日
    3
  • JasperReports的简单介绍

    JasperReports的简单介绍JasperReport 是世界上最流行的开源报告引擎 它是完全用 Java 编写的 它是能够使用的数据来自任何类型的数据源 并生成像素级的文档 可以查看 打印或导出在多种文档格式 包括 HTML PDF Excel OpenOffice 和 doc JasperReport 是一个用 Java 开发的开源的程序库 使用户能够透过它 利用 Java 语言来开发具有报告功能的程序 JasperReport 的模版采用

    2026年3月18日
    2
  • .sql文件导入错误「建议收藏」

    .sql文件导入错误「建议收藏」如果是使用Navicat导入的话,有一种情况是此sql文件是导出的.sql文件这样只导了数据sql,没有结构sql因为数据库中不存在该表,所以会报错这种情况.sql文件需要右击表,点击转储为SQL,选择数据和结构,再导入就好了!……

    2022年10月2日
    4
  • 数据挖掘工程师-需要掌握的技术

    数据挖掘工程师-需要掌握的技术了解 LR GBDT XGBOOST DNN 和 NLP 等常用模型的开源工具 熟悉语言 SAS 统计分析软件 Python Scala 编程语言等 熟练掌握数据挖掘 机器学习 优化算法的基础理论和方法 了解 Embbeding 等方法理念 熟悉 Hadoop Hive Spark Yarn Kafka Flink 等常用大数据生态系统的使用 熟悉 Linux 熟悉 Shell 脚本 熟悉深度学习框架 如 Tensorflow Caffe Theano MXNet PyTorch 等 以上是 boss 直聘上面开

    2025年7月5日
    5

发表回复

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

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