微信小程序项目需求:显示当前位置与目标位置之间的距离,优先选择最近的,关键思路如下,只需把对应坐标替换即可,当前坐标和目标坐标都可以通过微信小程序接口获取,坐标不唯一时需要进行循环遍历,排序算法较简单就不贴了
传入参数调用distance方法即可
Page({ /** * 生命周期函数--监听页面加载 */ onLoad: function (options) { var that = this; // 以北京故宫为例计算当前位置到其的距离,北京故宫坐标(116.403802, 39.915405) wx.getLocation({ type: 'gcj02', success: function (res) { console.log("当前坐标信息:", res) var distance = that.distance(res.latitude, res.longitude,39.918034,116.415192); console.log("当前位置距离北京故宫:", distance, "千米") } }) // 举个栗子验证一下distance方法的真实性和有效性 // 北京故宫坐标(116.403802,39.915405),上海虹桥机场坐标(121.334421,31.200479),地图测距结果为1066.6±10 var testdistance=that.distance(39.915405, 116.403802, 31.200479, 121.334421);//注意经纬度别混淆 console.log("北京故宫-上海虹桥机场的距离为:",testdistance,"千米");//结果让人很满意 }, /** * @creator 新猿意码 * @data 2019/01/17 * @desc 由经纬度计算两点之间的距离,la为latitude缩写,lo为longitude * @param la1 第一个坐标点的纬度 * @param lo1 第一个坐标点的经度 * @param la2 第二个坐标点的纬度 * @param lo2 第二个坐标点的经度 * @return (int)s 返回距离(单位千米或公里) * @tips 注意经度和纬度参数别传反了,一般经度为0~180、纬度为0~90 * 具体算法不做解释,有兴趣可以了解一下球面两点之间最短距离的计算方式 */ distance: function (la1, lo1, la2, lo2) { var La1 = la1 * Math.PI / 180.0; var La2 = la2 * Math.PI / 180.0; var La3 = La1 - La2; var Lb3 = lo1 * Math.PI / 180.0 - lo2 * Math.PI / 180.0; var s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(La3 / 2), 2) + Math.cos(La1) * Math.cos(La2) * Math.pow(Math.sin(Lb3 / 2), 2))); s = s * 6378.137; s = Math.round(s * 10000) / 10000; s = s.toFixed(2); return s; }, })