小demo大学外卖小程序,不太建议完全照搬,须要的可以在上面完成拓展,不喜勿喷!!!
这个功能最重要的就是路线规划,路线两端分别是点外卖的人,店家,送外卖的骑手,店家的位置,前端插口直接才能领到给后端,而用户的位置,因为地址是自己填的,因而后端也可以轻松的领到地址转为经经度。那骑手的位置呢?这就要从第三方货运插口去获取了,那得看实际的项目接入的是圆通,美团还是哒哒或则其他哪些。并且这个小demo也不须要这么复杂,即使没有骑手位置,那就简单模拟一下好了。首先在小程序上创建一张地图下来:
css
page,html,body {
width:100%;
height:100%;
}
.map-container {
width:100%;
height:100%;
}
.gaode-map {
width:100%;
height:100%;
}
js文件
const gaodeMap = require('../../amap-wx.js'); // 引入高德sdk
const map = new gaodeMap.AMapWX({
key: 'xxxxxxxx' // 高德申请的key
});
Page({
data: {
longitude: 116.397128, // 给个默认的经纬度 定位到北京天安门
latitude: 39.916527, //
distance: 0, // 骑手距离
cost: 0, // 大概时间
polyline: [], // 存放路线的经纬度
markers: [{ // 自己设置的三个mark标记,分别是 商家,用户,骑手
iconPath: "/images/shangjia.png",
id: 0,
latitude: 39.916527,
longitude: 116.397128,
width: 20,
height: 23
}, {
iconPath: "/images/weizhi.png",
id: 1,
latitude: 31.23035,
longitude: 121.473717,
width: 20,
height: 23
}, {
iconPath: "/images/qishou.png",
id: 2,
latitude: 31.23035,
longitude: 121.473717,
width: 20,
height: 23
}],
},
// 获取用户位置信息
getUserLocation() {
let that = this
wx.getLocation({
success: (res) => {
that.setData({
longitude: res.longitude,
latitude: res.latitude,
['markers[0].latitude']: res.latitude,
['markers[0].longitude']: res.longitude
}, () => {
map.getRidingRoute({
origin: '121.473717,31.23035', // 路线规划的起点 随便在我附近搜的位置转的经纬度
destination: `${res.longitude},${res.latitude}`, // 目的地经纬度
success: (data) => {
let points = [];
let distance = 0
let cost = 0
if (data.paths && data.paths[0] && data.paths[0].steps) {
var steps = data.paths[0].steps;
for (var i = 0; i < steps.length; i++) {
var poLen = steps[i].polyline.split(';');
for (var j = 0; j < poLen.length; j++) {
points.push({
longitude: parseFloat(poLen[j].split(',')[0]),
latitude: parseFloat(poLen[j].split(',')[1])
})
}
}
}
if (data.paths[0] && data.paths[0].distance) {
distance = data.paths[0].distance + '米'
}
if (data.paths[0] && data.paths[0].duration) {
cost = parseInt(data.paths[0].duration / 60) + '分钟'
}
that.setData({
polyline: [{
points: points,
color: "#0091ff",
width: 6
}],
distance,
cost,
['markers[2].longitude']: points[120].longitude,
['markers[2].latitude']: points[120].latitude
})
let tempNum = 0
// 设置一个定时器根据路线规划上的经纬度每100毫秒前进一步
let timer = setInterval(()=>{
if(tempNum >= points.length){
// 跑完了规划路线就停止
clearInterval(this.data.timer)
}
if(!this.data.timer){
// 将定时器设置为全局的,方便退出组件时销毁
this.setData({
timer:timer
})
}
//
this.setData({
['markers[2].longitude']: points[++tempNum].longitude,
['markers[2].latitude']: points[++tempNum].latitude
})
},100)
}
})
})
},
})
},
// 用户授权
userAuth() {
wx.getSetting({
success: (res) => {
if (!res.authSetting['scope.userLocation']) {
wx.authorize({
scope: 'scope.userLocation',
success: () => {
// 同意授权位置
this.getUserLocation()
},
fail: () => {
wx.showModal({
content: '拒绝授权将无法获取您的位置,请授权。',
showCancel: false,
success: (r) => {
if (r.confirm) {
// 打开设置页面让用户手动开启权限
wx.openSetting({
success:(v)=>{
}
})
}
}
})
}
})
}
},
})
},
onLoad: function () {
},
onShow:function(){
this.userAuth()
},
onUnload:function(){
clearInterval(this.data.timer)
}
})
s文件50行之下的那段代码是直接从高德文档copy过来的,顺便更改了一下。当调用高德的函数以后,传入两个点的经经度,他会返回一长串链表方式的经经度给我们:
就是我们须要的路线的经经度,在代码中经过for循环去取出经经度估算,就可以领到预计达到时间以及路程长短,这个估算并不难,但是高德文档本身就有,里面那段估算的代码就是现成的。为了模拟出那种骑手联通的疗效,我在下边加了一个定时器,每100纳秒让电动车图标按照路线的经经度联通一下,但实际情况的话,骑手的位置应当是由其他插口给后端才对,这儿只是为了瞧瞧疗效,仅此而已。地图上的那条路线,只是拿来给用户看的而已大学外卖小程序,由于他人在送外卖的时侯,不止送一份,就会去给他人,因而在地图上获取骑手位置的时侯,人家可能压根不在那条线上,也可能是走其他大路穿插,这都是正常的。还有就是骑手的位置也并非实时更新,我看美团的似乎就不是实时更新,而是隔一段时间更新一次,后端做个协程就好了,简单粗鲁。以上代码示例并非真实项目,只是为了看实现疗效写的小示例而已。
免责声明:部分文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性,如本站文章和转稿涉及版权等问题,请作者在及时联系本站,我们会尽快为您处理。