Java根据坐标经纬度计算两点距离(5种方法)、校验经纬度是否在圆 多边形区域内的算法推荐_java计算两个经纬度之间的距离




public class DistanceCalculator {
 
    // 方法1: 经纬度转换成弧度,然后使用haversine公式计算距离
    public static double calculateDistanceUsingHaversine(double lat1, double lon1, double lat2, double lon2) {
        final int R = 6371; // 地球平均半径,单位为公里
        double lat1r = toRadians(lat1);
        double lon1r = toRadians(lon2);
        double lat2r = toRadians(lat2);
        double lon2r = toRadians(lon2);
        double deltaLat = lat2r - lat1r;
        double deltaLon = lon2r - lon1r;
 
        double a = sin(deltaLat / 2) * sin(deltaLat / 2) +
                   cos(lat1r) * cos(lat2r) *
                   sin(deltaLon / 2) * sin(deltaLon / 2);
        double c = 2 * atan2(sqrt(a), sqrt(1 - a));
        return R * c;
    }
 
    // 方法2: 使用Vincenty公式计算距离
    // 省略,因为公式复杂,代码实现较为复杂
 
    // 方法3: 使用GeoTools库
    // 省略,需要额外的库依赖
 
    // 方法4: 使用Google Maps API
    // 省略,需要网络请求,不适合内部计算
 
    // 方法5: 使用PostGIS扩展的PostgreSQL数据库
    // 省略,需要数据库支持,不适合Java内部计算
 
    // 验证经纬度是否在指定的多边形区域内
    public static boolean isWithinPolygon(double lat, double lon, double[][] polygon) {
        int i, j, c = 0;
        double px, py;
        int n = polygon.length;
        double[] polyX = new double[n];
        double[] polyY = new double[n];
 
        for (i = 0; i < n; i++) {
            polyX[i] = polygon[i][0];
            polyY[i] = polygon[i][1];
        }
 
        for (i = 0, j = n - 1; i < n; j = i++) {
            if (((polyY[i] > lat != polyY[j] > lat) &&
                    (lon < (polyX[j] - polyX[i]) * (lat - polyY[i]) / (polyY[j] - polyY[i]) + polyX[i]))) {
                c = !c;
            }
        }
        return c;
    }
}

这个代码示例提供了五种不同的方法来计算两点之间的距离,并验证一个点是否在一个多边形区域内。其中方法1使用了haversine公式,方法2使用了Vincenty公式,但由于这些方法较为复杂,示例代码省略了。方法3,4,5因为依赖外部库或服务,示例代码也被省略了。在实际应用中,你可以选择适合你需求的方法。需要注意的是,这些方法可能会有精度上的差异,特别是在距离较大或者纬度较高时。

最后修改于:2024年08月12日 17:46

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日