冷门js数据处理记录

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根据经纬度换算行驶里程,因为业务需求,修改了小数点处理方式。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值