Bootstrap

计算两个地点的直线距离(需要两个地点的经纬度)

// 已只两点的经纬度  求两点的距离 
            function rad(d) {
                    return d * Math.PI / 180.0; 
                }  // 经纬度转换成三角函数中度分表形式。
                
            //需要参数两点的经纬度
         function countDist(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 = "";
              distance_str = distance * 1000;  //换算成米
              
              //如果需要换成KM为单位
                    // 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 distance_str;
                }

export default countDist
 

;