1、里程处理
微信小程序引入高德SDK时,无法使用计算里程的api,仅提供驾车、骑行、步行等路线规划的里程计算,这里的里程计算是最优路线的几种方案对应的里程数,与实际路程不符,但页面中又需要展示里程字段。所以需要计算一下。
计算两个坐标点之间的距离
getFlatternDistance(lon1, lat1, lon2, lat2) {
let DEF_PI = 3.14159265359; // PI
let DEF_2PI = 6.28318530712; // 2*PI
let DEF_PI180 = 0.01745329252; // PI/180.0
let DEF_R = 6370693.5; // radius of earth
let ew1, ns1, ew2, ns2;
let dx, dy, dew;
let distance;
// 角度转换为弧度
ew1 = lon1 * DEF_PI180;
ns1 = lat1 * DEF_PI180;
ew2 = lon2 * DEF_PI180;
ns2 = lat2 * DEF_PI180;
// 经度差
dew = ew1 - ew2;
// 若跨东经和西经180 度,进行调整
if (dew > DEF_PI) dew = DEF_2PI - dew;
else if (dew < -DEF_PI) dew = DEF_2PI + dew;
dx = DEF_R * Math.cos(ns1) * dew; // 东西方向长度(在纬度圈上的投影长度)
dy = DEF_R * (ns1 - ns2); // 南北方向长度(在经度圈上的投影长度)
// 勾股定理求斜边长
distance = Math.round(Math.sqrt(dx * dx + dy * dy) * 1000) / 1000;
return distance;
}
计算轨迹行驶的里程数(多个坐标点)
calculateMileage(history) {
let mileage = 0;
for (let i = 0; i < history.length - 1; i++) {
mileage += Number(
getFlatternDistance( // 这里引用两个点位之间的距离计算方法
history[i].longitude,
history[i].latitude,
history[i + 1].longitude,
history[i + 1].latitude
)
);
}
mileage = Math.round(mileage) / 1000;
return mileage
}
微信小程序实测,当坐标点数组有10000条以上,20000条以内,计算速度在2s左右(以内)。
原贴是js根据经纬度换算行驶里程,因为业务需求,修改了小数点处理方式。