package com.yqzx.common.util;
|
|
import java.util.HashMap;
|
import java.util.Map;
|
|
/**
|
* 计算坐标距离工具类
|
*
|
* @Author: lc
|
* @Date: 2019/5/23 19:10
|
*/
|
public class DistanceUtil {
|
|
private static double EARTH_RADIUS = 6378.137;
|
|
private static double rad(double d) {
|
return d * Math.PI / 180.0;
|
}
|
|
/**
|
* 通过经纬度获取距离(单位:米)
|
*
|
* @Author: lc
|
* @Date: 2019/5/23 19:14
|
*/
|
public static double getDistance(double lat1, double lng1, double lat2, double lng2) {
|
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;
|
s = Math.round(s * 10000d) / 10000d;
|
s = s * 1000;
|
return s;
|
}
|
|
/**
|
* 腾讯地图转换成百度地图坐标
|
* @param lng 腾讯经度
|
* @param lat 腾讯纬度
|
* @return 返回结果:经度,纬度
|
*/
|
public static Map<String, Double> txTransBd(double lng, double lat){
|
double x = lng, y = lat;
|
double z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * Math.PI);
|
double theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * Math.PI);
|
double bd_lng = z * Math.cos(theta) + 0.0065;
|
double bd_lat = z * Math.sin(theta) + 0.006;
|
Map<String, Double> map = new HashMap<>();
|
map.put("lng", bd_lng);
|
map.put("lat", bd_lat);
|
return map;
|
}
|
|
/**
|
* 百度地图坐标转换成腾讯地图坐标
|
* @param lng 百度经度
|
* @param lat 百度纬度
|
* @return 返回结果:纬度,经度
|
*/
|
public static String bdTransTx(double lng, double lat){
|
double x = lng - 0.0065, y = lat - 0.006;
|
double z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * Math.PI);
|
double theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * Math.PI);
|
double tx_lng = z * Math.cos(theta);
|
double tx_lat = z * Math.sin(theta);
|
return tx_lat+","+tx_lng;
|
}
|
}
|