首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在java中知道经度和纬度时,以米为单位计算距离

在java中知道经度和纬度时,以米为单位计算距离
EN

Stack Overflow用户
提问于 2009-05-08 01:38:08
回答 3查看 195.3K关注 0票数 77

可能重复:

Working with latitude/longitude values in Java

重复:

我需要计算由两个坐标给出的两点之间的距离。我正在做的项目是一个Java项目,所以Java代码会很棒,但也可以给出伪代码,然后我可以自己实现它:)

您可能知道,有三种表示坐标的方法:

  • Degrees:Minutes:Seconds (北纬49°30‘00“,123°30'00"W)
  • Degrees:Decimal分钟(49°30.0',-123°30.0'),(49d30.0m,-123d30.0')
  • Decimal度(49.5000°,-123.5000°),通常有4-6个十进制数。

这是我输入坐标的第三种方式,因此这个值的代码将是首选的:)

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2009-05-08 02:11:22

基于another question on stackoverflow,我得到了这个代码..这将以米为单位计算结果,而不是以英里为单位:)

代码语言:javascript
复制
 public static float distFrom(float lat1, float lng1, float lat2, float lng2) {
    double earthRadius = 6371000; //meters
    double dLat = Math.toRadians(lat2-lat1);
    double dLng = Math.toRadians(lng2-lng1);
    double a = Math.sin(dLat/2) * Math.sin(dLat/2) +
               Math.cos(Math.toRadians(lat1)) * Math.cos(Math.toRadians(lat2)) *
               Math.sin(dLng/2) * Math.sin(dLng/2);
    double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
    float dist = (float) (earthRadius * c);

    return dist;
    }
票数 192
EN

Stack Overflow用户

发布于 2011-12-12 09:26:16

你可以使用Java Geodesy Library for GPS,它使用的是考虑了地球表面曲率的Vincenty's formulae

实现是这样的:

代码语言:javascript
复制
import org.gavaghan.geodesy.*;

...

GeodeticCalculator geoCalc = new GeodeticCalculator();

Ellipsoid reference = Ellipsoid.WGS84;  

GlobalPosition pointA = new GlobalPosition(latitude, longitude, 0.0); // Point A

GlobalPosition userPos = new GlobalPosition(userLat, userLon, 0.0); // Point B

double distance = geoCalc.calculateGeodeticCurve(reference, userPos, pointA).getEllipsoidalDistance(); // Distance between Point A and Point B

生成的距离以米为单位。

票数 27
EN

Stack Overflow用户

发布于 2009-12-10 21:58:55

在C++中,它是这样完成的:

代码语言:javascript
复制
#define LOCAL_PI 3.1415926535897932385 

double ToRadians(double degrees) 
{
  double radians = degrees * LOCAL_PI / 180;
  return radians;
}

double DirectDistance(double lat1, double lng1, double lat2, double lng2) 
{
  double earthRadius = 3958.75;
  double dLat = ToRadians(lat2-lat1);
  double dLng = ToRadians(lng2-lng1);
  double a = sin(dLat/2) * sin(dLat/2) + 
             cos(ToRadians(lat1)) * cos(ToRadians(lat2)) * 
             sin(dLng/2) * sin(dLng/2);
  double c = 2 * atan2(sqrt(a), sqrt(1-a));
  double dist = earthRadius * c;
  double meterConversion = 1609.00;
  return dist * meterConversion;
}
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/837872

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档