安卓两点间距离计算

5

我有三种方法来计算距离,但是每一种方法都给了我不同的答案。

    double lat = 6.924049;
    double lng = 79.853807;

    double lat1 = 6.856461;
    double lng1 = 79.912748;

如何计算两点之间的距离,并将其以公里或米为单位百分比?

第一种方法 答案为9.967441199417708E-6

float[] results = new float[1];
Location.distanceBetween(lat / 1E6, lng / 1E6, lat1 / 1E6, lng1 / 1E6,results);
float s =results[0] * 0.000621371192f;
String a2 = Float.toString(s);

第二种方法 答案为6.1795527E6

double lat3 = lat / 1E6;
double lat2 = lat1 / 1E6;
double lon3 = lng / 1E6;
double lon2 = lng1 / 1E6;
double dLat = Math.toRadians(lat2 - lat3);
double dLon = Math.toRadians(lon2 - lon3);
double a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
Math.cos(Math.toRadians(lat1)) * Math.cos(Math.toRadians(lat2)) *
Math.sin(dLon / 2) * Math.sin(dLon / 2);
double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
// 6378.1 is gravity of earth
double asd = c * 6378.1;

第三种方法 答案为6.176576174444191

{
double a5 = distance(lat, lng, lat1, lng1);
String a6 = Double.toString(a5);
}
private double distance(double lat1, double lon1, double lat2, double lon2) {
        double theta = lon1 - lon2;
        double dist = Math.sin(deg2rad(lat1)) * Math.sin(deg2rad(lat2))
                + Math.cos(deg2rad(lat1)) * Math.cos(deg2rad(lat2))
                * Math.cos(deg2rad(theta));
        dist = Math.acos(dist);
        dist = rad2deg(dist);
        dist = dist * 60 * 1.1515;
        return (dist);
    }

    private double deg2rad(double deg) {
        return (deg * Math.PI / 180.0);
    }

    private double rad2deg(double rad) {
        return (rad * 180.0 / Math.PI);
    }

那么,如何计算两点之间的距离以及如何将其表示为公里或米?


如何计算两点之间的距离并将其以公里或米为单位表示? - Loshi
5个回答

10

1
返回此位置与给定位置之间的大约距离(以米为单位)。距离使用WGS84椭球定义。 - Lucifer

4
尝试使用这个公式。
double dist = Math.sqrt(Math.pow(x1 - x2, 2) + Math.pow(y1- y2, 2));

或者前往此链接(更适合您的情况):

http://www.movable-type.co.uk/scripts/latlong.html

该链接是一个有关IT技术的网站,可以帮助您解决相关问题。请点击以上链接以获取更多信息。

你知道有 Math.hypot(x, y) 这个函数。 - NikkyD

1

Google Maps Android API Utility Library 可以轻松计算距离等功能

您可以使用gradle进行操作


dependencies {
   compile 'com.google.maps.android:android-maps-utils:0.5+'
}

double distance = SphericalUtil.computeDistanceBetween(pointA, pointB);

0
double ER=3958.75;
    double dlong=Math.toRadians(longitude1-longitude);
                                double dlat=Math.toRadians(latitude1-latitude);
                                a=(Math.sin(dlat/2)*Math.sin(dlat/2))+Math.cos(Math.toRadians(latitude))*Math.cos(Math.toRadians(latitude1))*Math.sin(dlong/2)*Math.sin(dlong/2);               
                                c=2*Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
                                d=ER*c;

尝试使用这个,它会给出距离(公里),或者检查一下这个link


0

在计算巨大的圆形地球的距离时,没有办法找到准确的结果。您将有许多方法来找到这样的距离。现在从您的问题中,我想建议您使用第二或第三种方法,因为从我的角度来看,它们的结果有些相等(可能在几米内有轻微的距离)。

对于我的个人开发,我使用您的第三种方法。而为了精度,我在小数点后使用6位数字,

例如,在您的情况下,6.176576174444191,我使用6.176576


6.176576174444191的答案是什么?米吗?我怎样才能让它变成一个小数? - Loshi
使用十进制格式进行舍入,保留小数点后6位。 - Lucifer
问题在于@Lucifer,谷歌地图显示距离约为12公里,而这里只显示6.18米? - Loshi
@Loshi,这听起来有些误解。 - Lucifer
是的,那就是我的问题伙计... :( 而且distanceto和distance between给出了另外两个不同的答案。 - Loshi
在计算巨大的圆形地球的距离时,没有办法找到准确的结果。这是因为地球并非完美的球体,因此会存在变化。除此之外,确实可以准确地计算球体上两点之间的距离,只不过比平面更加复杂。 - nasch

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接