干货时间~关于使用高德地图实现路径规划的一些事情

需求分析

最近工作接到了与地图路径规划相关的需求:接口返回起始点位以及其中的途经点,前端展示对应驾车规划路径,路径规划分为最快捷模式与最短距离模式。

知识准备

高德地图是有向开发者提供路径规划api的,感兴趣的小伙伴可以先看下官方提供的api说明高德地图路径规划

案例展示

核心代码

js 复制代码
let driving
AMap.plugin('AMap.Driving', function () {
    //在回调函数中实例化插件,并使用插件功能
    driving = new AMap.Driving({
        policy: AMap.DrivingPolicy.LEAST_TIME, // 驾车路线规划策略
        map: 'map容器',
        panel: '',
     })
     driving.search(
         new AMap.LngLat('lng','lat'), // 起点
         new AMap.LngLat('lng','lat'), // 终点
         {
             waypoints:[new AMap.LngLat('lng','lat')] // 途经点
         },
         function (status, result) {
            if (status === 'complete') {
                console.log('绘制驾车路线完成')
            } else {
                console.error('获取驾车数据失败:' + result)
            }
        }
     )
})

这里我用到了最快捷模式与最短距离模式,对应设置 policy 属性的属性值即可,途经点通过数组的方式传递对应经纬度即可

功能优化

因为切换方式时路径是不会消失的,所以我们要根据 driving 是否存在来调用其 clear 方法清空上次保留的路径

js 复制代码
if(driving) {
    driving.clear()
}

补充

最后附上demo的源代码,有需要的小伙伴可以参考下,注意高德的key和安全密钥记得申请赋值一下哦~ 代码地址

相关推荐
铅笔侠_小龙虾几秒前
Flutter 实战: 计算器
开发语言·javascript·flutter
大模型玩家七七19 分钟前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
2501_9447114335 分钟前
JS 对象遍历全解析
开发语言·前端·javascript
发现一只大呆瓜1 小时前
虚拟列表:支持“向上加载”的历史消息(Vue 3 & React 双版本)
前端·javascript·面试
阔皮大师2 小时前
INote轻量文本编辑器
java·javascript·python·c#
lbb 小魔仙2 小时前
【HarmonyOS实战】React Native 表单实战:自定义 useReactHookForm 高性能验证
javascript·react native·react.js
_codemonster2 小时前
Vue的三种使用方式对比
前端·javascript·vue.js
全栈前端老曹2 小时前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
低代码布道师3 小时前
Next.js 16 全栈实战(一):从零打造“教培管家”系统——环境与脚手架搭建
开发语言·javascript·ecmascript
一位搞嵌入式的 genius3 小时前
深入 JavaScript 函数式编程:从基础到实战(含面试题解析)
前端·javascript·函数式