You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

30 lines
1.0 KiB

  1. /**
  2. * 计算两点之间的距离
  3. * @param {number} lat1 地点1精度
  4. * @param {number} lon1 地点1维度
  5. * @param {number} lat2 地点2精度
  6. * @param {number} lon2 地点2维度
  7. * @param {number} fixed 保留几位小数,默认0,单位km
  8. */
  9. export function calculateDistance(lat1, lon1, lat2, lon2, fixed = 0) { //计算两点距离
  10. let distance = 0
  11. if (!lat2 || !lon2) return distance
  12. //先强制转换一下(后端给的字符串)
  13. lat1 = parseFloat(lat1)
  14. lon1 = parseFloat(lon1)
  15. lat2 = parseFloat(lat2)
  16. lon2 = parseFloat(lon2)
  17. // 将角度转换为弧度
  18. const R = 6371; // 地球半径,单位公里
  19. const dLat = (lat2 - lat1) * Math.PI / 180;
  20. const dLon = (lon2 - lon1) * Math.PI / 180;
  21. lat1 = lat1 * Math.PI / 180;
  22. lat2 = lat2 * Math.PI / 180;
  23. // Haversine公式
  24. const a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
  25. Math.sin(dLon / 2) * Math.sin(dLon / 2) * Math.cos(lat1) * Math.cos(lat2);
  26. const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
  27. // 计算距离
  28. distance = R * c;
  29. return distance.toFixed(fixed)
  30. }