Как я могу рассчитать расстояние между несколькими широтой и долготой? - PullRequest
0 голосов
/ 30 сентября 2019

Я хочу вычислить общее расстояние между каждой точкой, которая содержит широту и длину, эти точки хранятся в локальной базе данных, поэтому сценарий таков: я хочу вычислить расстояние от точки a до b & b до c & c до d иточки (широта и долгота) сохраняются в базе данных с помощью Google Place API enter image description here

Все точки выбираются из базы данных.

Ответы [ 4 ]

0 голосов
/ 30 сентября 2019
float[] distanceWidth = new float[2];
Location.distanceBetween(
                startLatitude,
                startLongitude,
                endLatitude,
                endLongitude,
                distanceWidth);

//You will get float[] of results after Location.distanceBetween().

float distance = distanceHeight[0];
float distanceInKm = distance/1000;
0 голосов
/ 30 сентября 2019

Я не уверен, что понимаю суть этого вопроса. Нужно ли учитывать кривизну земли? Или это просто 2 случайные точки?

Если это первое : я могу показать вам эту ссылку, поскольку не могу вам помочь:

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

Если это последнее:

Предположим, 1 - широта, а 2 - долгота, так чтоa1 - широта точки A.

Calculating distance from 2 points

Вычисление 2 точек на плоскости выглядит примерно так:

Distance = sqrt((a1−b1)+(a2−b2))

Итак, для расчета, например, расстояние от D до E: sqrt((e1-d1) + (e2-d2))

0 голосов
/ 30 сентября 2019
class DistanceCalculator
{
    public static void main (String[] args) throws java.lang.Exception
    {
        System.out.println(distance(32.9697, -96.80322, 29.46786, -98.53506, "M") + " Miles\n");
        System.out.println(distance(32.9697, -96.80322, 29.46786, -98.53506, "K") + " Kilometers\n");
        System.out.println(distance(32.9697, -96.80322, 29.46786, -98.53506, "N") + " Nautical Miles\n");
    }

    private static double distance(double lat1, double lon1, double lat2, double lon2, String unit) {
        if ((lat1 == lat2) && (lon1 == lon2)) {
            return 0;
        }
        else {
            double theta = lon1 - lon2;
            double dist = Math.sin(Math.toRadians(lat1)) * Math.sin(Math.toRadians(lat2)) + Math.cos(Math.toRadians(lat1)) * Math.cos(Math.toRadians(lat2)) * Math.cos(Math.toRadians(theta));
            dist = Math.acos(dist);
            dist = Math.toDegrees(dist);
            dist = dist * 60 * 1.1515;
            if (unit == "K") {
                dist = dist * 1.609344;
            } else if (unit == "N") {
                dist = dist * 0.8684;
            }
            return (dist);
        }
    }
}
0 голосов
/ 30 сентября 2019

Вы можете рассчитать расстояние между двумя точками местоположения без использования мест api

    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);
}
...