Obliczanie odległości między dwoma lokalizacjami geograficznymi

Proszę rzucić trochę światła na tę sytuację

W tej chwili mam dwie tablice o szerokości i długości geograficznej pobliskich miejsc, a także o lokalizacji użytkownika latiude i longiude teraz chcę obliczyć odległość między lokalizacją użytkownika a pobliskimi miejscami i chcę je pokazać w listview.

Wiem, że istnieje metoda obliczania odległości jako

public static void distanceBetween (double startLatitude, double startLongitude, double endLatitude, double endLongitude, float[] results);

Teraz problem polega na tym, jak przekazać te dwie macierze o pobliskiej szerokości i długości geograficznej w ta metoda i uzyskać tablicę odległości.

Author: stema, 2011-11-08

7 answers

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

Spójrz w dal

Zwraca przybliżoną odległość w metrach między tą lokalizacją i danej lokalizacji. Odległość jest określona za pomocą elipsoidy WGS84.

Lub distanceBetween

Oblicza przybliżoną odległość w metrach między dwoma lokalizacjami, oraz opcjonalnie początkowe i końcowe łożyska najkrótszej drogi między oni. Odległość i łożysko są zdefiniowana za pomocą elipsoidy WGS84.

Możesz utworzyć obiekt Location z szerokości i długości geograficznej:

Location locationA = new Location("point A");

locationA.setLatitude(latA);
locationA.setLongitude(lngA);

Location locationB = new Location("point B");

locationB.setLatitude(latB);
locationB.setLongitude(lngB);

float distance = locationA.distanceTo(locationB);

Lub

private double meterDistanceBetweenPoints(float lat_a, float lng_a, float lat_b, float lng_b) {
    float pk = (float) (180.f/Math.PI);

    float a1 = lat_a / pk;
    float a2 = lng_a / pk;
    float b1 = lat_b / pk;
    float b2 = lng_b / pk;

    double t1 = Math.cos(a1) * Math.cos(a2) * Math.cos(b1) * Math.cos(b2);
    double t2 = Math.cos(a1) * Math.sin(a2) * Math.cos(b1) * Math.sin(b2);
    double t3 = Math.sin(a1) * Math.sin(b1);
    double tt = Math.acos(t1 + t2 + t3);
   
    return 6366000 * tt;
}
 190
Author: Karthi,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2020-11-29 14:42:32

Spróbuj Tego Kodu. tutaj mamy dwie wartości długości i szerokości geograficznej oraz selected_location.funkcja distanceTo (near_locations) zwraca odległość między tymi miejscami w metrach.

Location selected_location=new Location("locationA");
            selected_location.setLatitude(17.372102);
            selected_location.setLongitude(78.484196);
Location near_locations=new Location("locationB");
            near_locations.setLatitude(17.375775);
            near_locations.setLongitude(78.469218);
double distance=selected_location.distanceTo(near_locations);

Tutaj "odległość" to odległość między lokalizacjąa i lokalizacjąb (w metrach)

 17
Author: sandeepmaaram,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-03-09 16:30:43

Istnieje tylko jedna lokalizacja użytkownika, więc można iterację listę pobliskich miejsc można wywołać funkcję distanceTo(), aby uzyskać odległość, można przechowywać w tablicy, jeśli chcesz.

Z tego, co rozumiem, distanceBetween() jest dla odległych miejsc, jej wyjście to elipsoida WGS84.

 3
Author: Reno,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2011-11-08 11:50:23
    private static Double _MilesToKilometers = 1.609344;
    private static Double _MilesToNautical = 0.8684;


    /// <summary>
    /// Calculates the distance between two points of latitude and longitude.
    /// Great Link - http://www.movable-type.co.uk/scripts/latlong.html
    /// </summary>
    /// <param name="coordinate1">First coordinate.</param>
    /// <param name="coordinate2">Second coordinate.</param>
    /// <param name="unitsOfLength">Sets the return value unit of length.</param>
    public static Double Distance(Coordinate coordinate1, Coordinate coordinate2, UnitsOfLength unitsOfLength)
    {

        double theta = coordinate1.getLongitude() - coordinate2.getLongitude();
        double distance = Math.sin(ToRadian(coordinate1.getLatitude())) * Math.sin(ToRadian(coordinate2.getLatitude())) +
                       Math.cos(ToRadian(coordinate1.getLatitude())) * Math.cos(ToRadian(coordinate2.getLatitude())) *
                       Math.cos(ToRadian(theta));

        distance = Math.acos(distance);
        distance = ToDegree(distance);
        distance = distance * 60 * 1.1515;

        if (unitsOfLength == UnitsOfLength.Kilometer)
            distance = distance * _MilesToKilometers;
        else if (unitsOfLength == UnitsOfLength.NauticalMiles)
            distance = distance * _MilesToNautical;

        return (distance);

    }
 3
Author: user2871325,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-10-11 14:11:58

DistanceTo da ci odległość w metrach między dwoma podanymi lokalizacjami.odległość (cel podróży).

DistanceBetween podaje również odległość, ale zapisuje ją w tablicy float( wyniki [0]). doc mówi, że jeśli results ma długość 2 lub większą, początkowe łożysko jest zapisywane w results[1]. Jeśli results ma długość 3 lub większą, łożysko końcowe jest zapisywane w results [2]

Mam nadzieję, że to pomoże

I ' ve used distance to get the distance z punktu A do B myślę, że to jest droga do zrobienia.

 1
Author: eOnOe,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-09-05 14:40:33
public double distance(Double latitude, Double longitude, double e, double f) {
        double d2r = Math.PI / 180;

        double dlong = (longitude - f) * d2r;
        double dlat = (latitude - e) * d2r;
        double a = Math.pow(Math.sin(dlat / 2.0), 2) + Math.cos(e * d2r)
                * Math.cos(latitude * d2r) * Math.pow(Math.sin(dlong / 2.0), 2)
        double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
        double d = 6367 * c;
                return d;

    }
 0
Author: Vinay,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2016-04-19 17:35:28

Chciałem sobie to zaimplementować, skończyło się na przeczytaniu strony wikipedii na Wzór odległości wielkich kół , ponieważ żaden kod nie był wystarczająco czytelny, aby użyć go jako podstawy.

C# przykład

    /// <summary>
    /// Calculates the distance between two locations using the Great Circle Distance algorithm
    /// <see cref="https://en.wikipedia.org/wiki/Great-circle_distance"/>
    /// </summary>
    /// <param name="first"></param>
    /// <param name="second"></param>
    /// <returns></returns>
    private static double DistanceBetween(GeoLocation first, GeoLocation second)
    {
        double longitudeDifferenceInRadians = Math.Abs(ToRadians(first.Longitude) - ToRadians(second.Longitude));

        double centralAngleBetweenLocationsInRadians = Math.Acos(
            Math.Sin(ToRadians(first.Latitude)) * Math.Sin(ToRadians(second.Latitude)) +
            Math.Cos(ToRadians(first.Latitude)) * Math.Cos(ToRadians(second.Latitude)) *
            Math.Cos(longitudeDifferenceInRadians));

        const double earthRadiusInMeters = 6357 * 1000;

        return earthRadiusInMeters * centralAngleBetweenLocationsInRadians;
    }

    private static double ToRadians(double degrees)
    {
        return degrees * Math.PI / 180;
    }
 0
Author: Henrick Kakutalua,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2020-03-04 14:27:09