Android 判断某个点是否在指定范围内的方法

前提提示:基于百度地图做的逻辑


                //处理点的辐射范围打卡
                if (userAddress != null) {
                    BigDecimal bdLatitude = BigDecimal.valueOf(latitude);
                    BigDecimal bdLongitude = BigDecimal.valueOf(longitude);
                    for (UserAddress address : userAddress) {
                        InRange inRange = new InRange();
                        inRange.setLat(bdLatitude);
                        inRange.setLng(bdLongitude);
                        inRange.setLat1(new BigDecimal(address.getLatitude()));
                        inRange.setLng1(new BigDecimal(address.getLongitude()));
                        inRange.setRaduis(Integer.parseInt(address.getDistance()));
                        boolean inRange1 = NettyUtils.isInRange(inRange);
                        if (inRange1) {
                            //放行 在区域内
                            setStatus(1);
                            return;
                        }
                    }
                }

其中:BigDecimal是我第一次见,chat了一下获得到的知识如下:

BigDecimal 是 Java 中的一个类,用于精确表示和计算任意精度的浮点数。它可以用于处理需要高精度计算的情况,例如金融计算或者需要避免浮点数精度丢失的情况。

与普通的浮点数类型(如 double 或 float)不同,BigDecimal 使用任意精度的算术运算,可以精确表示十进制小数,并且不会丢失精度。

在 Java 中,BigDecimal 类提供了各种方法和操作符来执行基本的算术运算、比较和舍入操作。它还允许设置精度和舍入模式,以满足特定的计算需求。

总之,BigDecimal 类是 Java 中用于精确表示和计算任意精度的数值的一个重要工具类。

InRange里的详情如下:

import java.math.BigDecimal;

public class InRange {
    public InRange() {
    }

    public InRange(int raduis, BigDecimal lat, BigDecimal lng, BigDecimal lat1, BigDecimal lng1) {
        this.raduis = raduis;
        this.lat = lat;
        this.lng = lng;
        this.lat1 = lat1;
        this.lng1 = lng1;
    }

    private int raduis;
    //点 纬度
    private BigDecimal lat;
    //点 经度
    private BigDecimal lng;
    //圆 纬度
    private BigDecimal lat1;
    //圆 经度
    private BigDecimal lng1;

    public int getRaduis() {
        return raduis;
    }

    public void setRaduis(int raduis) {
        this.raduis = raduis;
    }

    public BigDecimal getLat() {
        return lat;
    }

    public void setLat(BigDecimal lat) {
        this.lat = lat;
    }

    public BigDecimal getLng() {
        return lng;
    }

    public void setLng(BigDecimal lng) {
        this.lng = lng;
    }

    public BigDecimal getLat1() {
        return lat1;
    }

    public void setLat1(BigDecimal lat1) {
        this.lat1 = lat1;
    }

    public BigDecimal getLng1() {
        return lng1;
    }

    public void setLng1(BigDecimal lng1) {
        this.lng1 = lng1;
    }
}

下面这段代码看起来是一个用于判断某个点是否在指定范围内的方法。它使用了经纬度坐标计算两点之间的距离,并与给定的半径进行比较来判断是否在范围内。

在这段代码中,首先定义了地球半径 R 为 6378137.0 米。然后根据传入的参数计算了两点之间的经纬度差值,并使用球面三角形的公式计算了两点之间的距离 d。最后将距离四舍五入为整数,然后与给定的半径进行比较,如果距离小于等于半径则返回 true,否则返回 false。

需要注意的是,这段代码使用了数学公式和常量来进行地理位置计算,而且代码中的角度转弧度的计算也是正确的。这段代码可以用于判断一个经纬度坐标是否在另一个经纬度坐标指定的范围内。

public class NettyUtils {
    public static boolean isInRange(InRange inRange) {
        double R = 6378137.0;
        double dLat = (inRange.getLat1().doubleValue() - inRange.getLat().doubleValue()) * Math.PI / 180;
        double dLng = (inRange.getLng1().doubleValue() - inRange.getLng().doubleValue()) * Math.PI / 180;
        double a = Math.sin(dLat / 2) * Math.sin(dLat / 2) + Math.cos(inRange.getLat().doubleValue() * Math.PI / 180) * Math.cos(inRange.getLat1().doubleValue() * Math.PI / 180) * Math.sin(dLng / 2) * Math.sin(dLng / 2);
        double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
        double d = R * c;
        double dis = Math.round(d);
        if (dis <= inRange.getRaduis()) {  //点在圆内
            return true;
        } else {
            return false;
        }
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。