Java 如何计算多个纬度和经度之间的距离?

Java 如何计算多个纬度和经度之间的距离?,java,android,google-maps,google-maps-api-3,google-maps-markers,Java,Android,Google Maps,Google Maps Api 3,Google Maps Markers,我想计算每个点之间的总距离,这两个点都包含lat和long,这些点存储在本地数据库中,所以场景是我想计算从点a到b&b到c&c到d的距离,这些点SLAT和long使用google place api存储在数据库中 所有点都是从数据库中提取的。您可以计算两个位置点之间的距离,而无需使用places api private double distance(double lat1, double lon1, double lat2, double lon2) { double

我想计算每个点之间的总距离,这两个点都包含lat和long,这些点存储在本地数据库中,所以场景是我想计算从点a到b&b到c&c到d的距离,这些点SLAT和long使用google place api存储在数据库中


所有点都是从数据库中提取的。

您可以计算两个位置点之间的距离,而无需使用places 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);
}

我不确定我是否理解这个问题的范围。你需要考虑地球的曲率吗?或者只是2个随机点

如果是第一个:我可以向您显示此链接,因为我无法帮助您:

如果是后者:

假设1是纬度,2是经度,所以a1是点A的纬度

计算平面上的两个点类似于这样:

距离=sqrta1−b1+a2−b2


例如,要计算从D到E的距离是:sqrte1-d1+e2-d2,步行距离还是直线距离?但我正在存储应用程序所需的Lat和Long using places api。要计算距离,您不需要places api。这就是我所说的是,您是对的,但根据图表,数据库中存储了多个点。这些点存储在places api中,我现在要创建两个点之间的距离每个点都有点的列表位置,首先计算位置1和位置2之间的距离,然后计算位置2和位置3之间的距离,并将距离加起来。我有动态点,而不是静态点。点最多可以是20点,也可以是30点。我想您的程序中已经存储了坐标。
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);
        }
    }
}
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;