安卓(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;
    }

浪费了一个小时。。。。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

朱 江

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值