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 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 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; } }