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