计算地图上点与线段距离

将地球看作一个标准球体,计算点到线段的距离。java

计算两点间的球面距离函数

/**
 *
 * a点经度,a点纬度,b点经度,b点纬度
 *
 */
public static double calcP2P(double alon, double alat, double blon, double blat) {
        double R = 6378.137;// 地球半径(公里)
        // 判断点是在北半球仍是南半球,本程序中输入的数据若为负则表示在南边球
        double distance = 0.0D;

        double _alat = (alat) * (Math.PI / 180); // 弧度
        double _alon = (alon) * (Math.PI / 180);
        double _blat = (blat) * (Math.PI / 180);
        double _blon = (blon) * (Math.PI / 180);

        double c = Math.sin(_alat) * Math.sin(_blat) + Math.cos(_alat) * Math.cos(_blat) * Math.cos(_alon - _blon); // Java中三角函数角度以弧度制表示
        if (c > 1) {
            c = 1;
        }
        distance = Math.acos(c) * R; // 弧长公式:弧长 = 弧度 * 半径
        if (distance <= 0.01) { // GPS偏差
            distance = 0.0D;
        }
        return distance;
}

计算点到线段的距离code

/**
 *
 * x,y--点的经度和纬度
 * x1,y1--线段某个端点的经度和纬度
 * x2,y2--线段另一个端点的经度和纬度
 *
 */
public static double calcP2L(double x, double y, double x1, double y1, double x2, double y2) {
        double d1 = (x2 - x1) * (x - x1) + (y2 - y1) * (y - y1);
        if (d1 < 0) {
            return calcP2P(x, y, x1, y1);
        }
        double d2 = (x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1);
        if (d1 >= d2) {
            return calcP2P(x, y, x2, y2);
        }
        double r = d1 / d2;
        double px = x1 + (x2 - x1) * r;
        double py = y1 + (y2 - y1) * r;
        return calcP2P(x, y, px, py);
    }
相关文章
相关标签/搜索