登录 |  注册
首页 >  编程语言 >  Java常用开发工具类案例代码 >  地球两点间经纬度距离计算公式

地球两点间经纬度距离计算公式

地理位置模型

package com.yukx.util;
import lombok.Data;
/**
 * @description: 地理位置模型
 */
@Data
public class GeoInfoModel {
    /**
     * 经度
     */
    private Double lng;
    /**
     * 纬度
     */
    private Double lat;
}

距离计算方法

package com.yukx.util;

/**
 * 百度距离计算
 */
public class GeoDistanceUtil {
    private GeoDistanceUtil() {
    }

    /**
     * 地球半径
     */
    private static double EARTH_RADIUS = 6378.137;
    /**
     * 计算距离
     * @param startPoint 起始经纬度
     * @param endPoint   目标经纬度
     * @return
     */
    private static Double getDistance(GeoInfoModel startPoint, GeoInfoModel endPoint) {
        if (!isGeoValid(startPoint) || !isGeoValid(endPoint)) {
            return null;
        }
        Double startLatRad = rad(startPoint.getLat());
        Double endLatRad = rad(endPoint.getLat());
        double latDistance = startLatRad - endLatRad;
        double lngDistance = rad(startPoint.getLng() - endPoint.getLng());
        return 2 * EARTH_RADIUS * Math.asin(Math.sqrt(Math.pow(Math.sin(latDistance / 2), 2) +
                Math.cos(startLatRad) *
                        Math.cos(endLatRad) *
                        Math.pow(Math.sin(lngDistance / 2), 2)));
    }

    /**
     * 校验坐标是否正确
     * @param point
     * @return
     */
    private static boolean isGeoValid(GeoInfoModel point) {
        return point != null && Math.abs(point.getLat()) <= 90 && Math.abs(point.getLng()) <= 180;
    }

    /**
     * 地球半径转弧度
     * @param d
     * @return
     */
    private static double rad(double d) {
        return d * Math.PI / 180.0;
    }
}
上一篇: 使用Redis实现门店最新5条购买记录
下一篇: myBatis动态传入表名、字段名(列名)进行查询
推荐文章
  • PHP字符串变量一个字符串(string)就是由一系列的字符组成,其中每个字符等同于一个字节。字符串变量用于存储并处理文本。PHP中的字符串变量字符串变量用于包含有字符的值。在创建字符串之后,我们就可以对它进行操作了。您可以直接在函数中使用字符串,或者把它存储在变量中。在下面的实例中,我们创建一个名
  • ASP.NET教程ASP.NET又称为ASP+,基于.NETFramework的Web开发平台,是微软公司推出的新一代脚本语言。ASP.NET是一个使用HTML、CSS、JavaScript和服务器脚本创建网页和网站的开发框架。ASP.NET支持三种不一样的开发模式:WebPages(Web页面)、
  • C# 判断判断结构要求程序员指定一个或多个要评估或测试的条件,以及条件为真时要执行的语句(必需的)和条件为假时要执行的语句(可选的)。下面是大多数编程语言中典型的判断结构的通常形式:判断语句C#提供了以下类型的判断语句。点击链接查看每个语句的细节。语句描述if语句一个 if语句 由一个布尔表达式后跟
  • C#循环有的时候,可能需要多次执行同一块代码。通常情况下,语句是顺序执行的:函数中的第一个语句先执行,接着是第二个语句,依此类推。编程语言提供了允许更为复杂的执行路径的多种控制结构。循环语句允许我们多次执行一个语句或语句组,下面是大多数编程语言中循环语句的通常形式:循环类型C#提供了以下几种循环类型
  • C#数组(Array)数组是一个存储相同类型元素的固定大小的顺序集合。数组是用来存储数据的集合,一般认为数组是一个同一类型变量的集合。声明数组变量并不是声明number0、number1、...、number99一个个单独的变量,而是声明一个就像numbers这样的变量,然后使用numbers[0]
  • ASP.NET是一个由微软公司开发的用于构建Web应用程序的框架,它是.NETFramework的一部分。它提供了一种模型-视图-控制器(MVC)架构、Web表单以及最新的ASP.NETCore中的RazorPages等多种开发模式,可以用来创建动态网页和Web服务。以下是一些基础的ASP.NET编
学习大纲