距離計算方法工具類:
import java.math.BigDecimal;
/**
* @author lovelyhedong
* @date 2020年8月21日 22:49:53
*/
public class LngLatUtils {
// 赤道半徑
private static final double EARTH_RADIUS = 6378137;
/**
* 根據(jù)經(jīng)緯度獲取兩點的距離(單位米)
*/
public static Double getDistance(double lng1, double lat1, double lng2, double lat2) {
double radLat1 = rad(lat1);
double radLat2 = rad(lat2);
double a = radLat1 - radLat2;
double b = rad(lng1) - rad(lng2);
double s = 2 * Math.asin(Math.sqrt(
Math.pow(Math.sin(a / 2), 2) + Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2)));
s = s * EARTH_RADIUS;
return s;
}
private static double rad(double d) {
return d * Math.PI / 180.0;
}
/**
* 根據(jù)經(jīng)緯度獲取兩點的距離(單位米)
*/
public static Double getDistance(BigDecimal lng1, BigDecimal lat1, BigDecimal lng2, BigDecimal lat2) {
return getDistance(lng1.doubleValue(), lat1.doubleValue(), lng2.doubleValue(), lat2.doubleValue());
}
/**
* 根據(jù)經(jīng)緯度獲取兩點的距離(單位公里/千米)
*/
public static Double getKilometer(double lng1, double lat1, double lng2, double lat2) {
return Math.round(getDistance(lng1, lat1, lng2, lat2)) / 1000d;
}
/**
* 根據(jù)經(jīng)緯度獲取兩點的距離(單位公里/千米)
*/
public static Double getKilometer(BigDecimal lng1, BigDecimal lat1, BigDecimal lng2, BigDecimal lat2) {
return Math.round(getDistance(lng1.doubleValue(), lat1.doubleValue(), lng2.doubleValue(), lat2.doubleValue())) / 1000d;
}
}
導入依賴包計算方式:
import org.gavaghan.geodesy.Ellipsoid;
import org.gavaghan.geodesy.GeodeticCalculator;
import org.gavaghan.geodesy.GlobalCoordinates;
/**
* 需要的依賴
* <dependency>
* <groupId>org.gavaghan</groupId>
* <artifactId>geodesy</artifactId>
* <version>1.1.3</version>
* </dependency>
*/
public class MapTest {
public static void main(String[] args) {
//相差25米 大約等于0.024公里
Double fristLng = 104.02436160776520;//第一個經(jīng)度
Double fristLat = 30.75109533912993;//第一個緯度
Double secoundLng = 104.02270936701203;//第二個經(jīng)度
Double secoundLat = 30.75073113557945;//第二個緯度
System.out.println(Math.round(getDistance(fristLng,
fristLat,
secoundLng,
secoundLat)) / 1000d);//這里除以1000,換算成了公里,如果不除以1000就是米數(shù)
}
public static double getDistance(double longitudeFrom, double latitudeFrom, double longitudeTo, double latitudeTo) {
GlobalCoordinates source = new GlobalCoordinates(latitudeFrom, longitudeFrom);
GlobalCoordinates target = new GlobalCoordinates(latitudeTo, longitudeTo);
return new GeodeticCalculator().calculateGeodeticCurve(Ellipsoid.WGS84, source, target).getEllipsoidalDistance();
}
}
原文鏈接:https://blog.csdn.net/MiaodXindng/article/details/108160926
還可以看看
其他文章,謝謝您的閱讀。
網(wǎng)站申明:系本文編輯轉載,來源于網(wǎng)絡,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點和對其真實性負責,所有權歸屬原作者。如內(nèi)容、圖片有任何版權問題,請
聯(lián)系我們刪除。