随身笔记
随身笔记

JS实现根据两点位置的经纬度获取距离

// 经纬度转换成三角函数中度分表形式。
        function rad(d) {
            return d * Math.PI / 180.0; 
        }


        // 根据经纬度计算距离,参数分别为第一点的纬度,经度;第二点的纬度,经度
        function getDistance(lat1, lng1, lat2, lng2) {

            var radLat1 = rad(lat1);
            var radLat2 = rad(lat2);
            var a = radLat1 - radLat2;
            var b = rad(lng1) - rad(lng2);
            var s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) +
                Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2)));
            s = s * 6378.137; // EARTH_RADIUS;
            s = Math.round(s * 10000) / 10000; //输出为公里

            var distance = s;
            var distance_str = "";

            if (parseInt(distance) >= 1) {
                distance_str = distance.toFixed(1) + "km";
            } else {
                distance_str = distance * 1000 + "m";
            }

            //s=s.toFixed(4);

            console.info('lyj 距离是', s);
            console.info('lyj 距离是', distance_str);
            return s;
        }

获取经纬度:https://lbs.amap.com/tools/picker

获取经纬度,及两点距离案例:https://developer.amap.com/demo/jsapi-v2/example/calcutation/calculate-distance-between-two-markers

https://www.cnblogs.com/feiquan/p/11338691.html

没有标签
首页      前端资源      JS实现根据两点位置的经纬度获取距离

随身笔记

JS实现根据两点位置的经纬度获取距离
// 经纬度转换成三角函数中度分表形式。 function rad(d) { return d * Math.PI / 180.0; } // 根据经纬度计算距离,参数分别为第一点的纬…
扫描二维码继续阅读
2021-11-11