【问题标题】:Android distance between two points两点之间的Android距离
【发布时间】:2012-07-17 01:44:15
【问题描述】:

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

    double lat = 6.924049;
    double lng = 79.853807;

    double lat1 = 6.856461;
    double lng1 = 79.912748;

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

第一种方式 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 上计算百分比?还是米?

【问题讨论】:

  • 如何计算两点之间的距离以及如何按公里计算它的百分比?还是米?

标签: android map


【解决方案1】:

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

使用 distanceTo 或 distanceBetween 方法。 不如试试Android的Location方法here

您可以根据纬度和经度创建 Location 对象:

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

【讨论】:

  • 返回此位置与给定位置之间的近似距离(以米为单位)。距离是使用 WGS84 椭球定义的。
【解决方案2】:

试试这个公式

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

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

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

【讨论】:

  • 你知道有 Math.hypot(x, y)
【解决方案3】:

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

你可以用 gradle 来使用它


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

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

【讨论】:

    【解决方案4】:

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

    为了我个人的发展,我使用你的第三种方法。为了精确,我在小数点后使用 6 位数字,

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

    【讨论】:

    • 6.176576174444191 答案是什么?米?我怎样才能使它成为一个小人物?
    • 使用小数格式四舍五入,小数点后6位。
    • 问题是@Lucifer,在谷歌地图中它给出的距离约为 12 公里,而在这里它只有 6.18 米?
    • @Loshi,这听起来有些误解
    • 是的,那是我的问题伙伴.... :( 和 distanceto 和 distance between 给出了另外两个不同的答案
    【解决方案5】:
    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检查

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2019-01-23
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-09-16
      • 2010-10-30
      • 1970-01-01
      • 2017-07-06
      相关资源
      最近更新 更多