两点之间的Android距离

时间:2012-07-18 04:29:33

标签: android map

我有3种计算距离的方法,所有3种方法给出了不同的答案,

    double lat = 6.924049;
    double lng = 79.853807;

    double lat1 = 6.856461;
    double lng1 = 79.912748;

如何计算两点之间的距离以及如何在Km上百分比?还是米?

第一路 ans = 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);

第二路 ans = 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;

第三种方式 ans = 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);
    }

那么,如何计算两点之间的距离以及如何在KM上百分比?还是米?

5 个答案:

答案 0 :(得分:10)

http://developer.android.com/reference/android/location/Location.html

使用方法之间距离To orr distance。 为什么不尝试Android的位置方法here

您可以从纬度和经度创建位置对象:

Location location = new Location("");
location.setLatitude(lat);
location.setLongitude(lon);

答案 1 :(得分:3)

试试这个公式

double dist = Math.sqrt(Math.pow(x1 - x2, 2) + Math.pow(y1- y2, 2));

或者转到此链接(更可能更适合您的情况):

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

答案 2 :(得分: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);

答案 3 :(得分:0)

在计算巨大圆形地点(地球)的距离时,无法找到准确的结果。你将有很多方法来找到这样的距离。现在从你的问题,我建议你使用第二种或第三种方法,因为从我的观点来看,它们的结果有些相等(可能是几米内的小距离)。

对于我的个人发展,我使用你的第三种方法。而对于精度我使用小数点后的6位数,

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

答案 4 :(得分: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

进行检查