安卓(JAVA)已知两点经纬度,求出一条线上几等分的点的经纬度。

话不多说,直接上代码。

 /**
     * 计算两点之间等距的经纬度
     */
    private List<LatLng> getDengLatLng(int number) {
        double aaa, bbb, ccc = 0, ddd = 0;
        List<LatLng> latLngs = new ArrayList<>();
        for (int i = 1; i < number + 1; i++) {
            if (latLng_a.longitude > latLng_b.longitude && latLng_a.latitude > latLng_b.latitude) {
                aaa = (latLng_a.longitude - latLng_b.longitude) / (number + 1);
                ccc = latLng_b.longitude + aaa * (i);
                bbb = (latLng_a.latitude - latLng_b.latitude) / (number + 1);
                ddd = bbb * (i) + latLng_b.latitude;
                Log.e(TAG, "getLatLng:a " + ddd + "   " +ccc);
            } else if (latLng_a.longitude < latLng_b.longitude && latLng_a.latitude < latLng_b.latitude) {
                aaa = (latLng_b.longitude - latLng_a.longitude) / (number + 1);
                ccc = latLng_a.longitude + aaa * (i);
                bbb = (latLng_b.latitude - latLng_a.latitude) / (number + 1);
                ddd = latLng_a.latitude + bbb * i;
                Log.e(TAG, "getLatLng:b " + ddd + "   " +ccc);
            } else if (latLng_a.longitude > latLng_b.longitude && latLng_a.latitude < latLng_b.latitude) {
                aaa = (latLng_a.longitude - latLng_b.longitude) / (number + 1);
                ccc = latLng_b.longitude + aaa * (number+1-i);
                bbb = (latLng_b.latitude - latLng_a.latitude) / (number + 1);
                ddd = latLng_a.latitude + bbb * i;
                Log.e(TAG, "getLatLng:c " + ddd + "   " +ccc);
            } else if (latLng_a.longitude < latLng_b.longitude && latLng_a.latitude > latLng_b.latitude) {
                aaa = (latLng_b.longitude - latLng_a.longitude) / (number + 1);
                ccc = latLng_a.longitude + aaa * (i);
                bbb = (latLng_a.latitude - latLng_b.latitude) / (number + 1);
                ddd = latLng_a.latitude - bbb * i;
                Log.e(TAG, "getLatLng:d " + ddd + "   " +ccc);
            }

            latLngs.add(new LatLng(ddd, ccc));
        }

        return latLngs;
    }

浪费了一个小时。。。。

猜你喜欢

转载自blog.csdn.net/haojiagou/article/details/82021177
今日推荐