JS百度地图API开发:展示一起点多终点的驾车导航路线显示与时间计算,并按时间长短排列(超详细)

本文主要是介绍JS百度地图API开发:展示一起点多终点的驾车导航路线显示与时间计算,并按时间长短排列(超详细),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先要自己在百度地图控制台申请一个自己的密钥,替换掉代码中间的密钥。这段代码需要注意的就是按照时间的长短排列,这份代码无论怎么刷新都不会乱掉排序顺序。代码注释解释的非常详细,大家自己看就行了。有什么不懂的可以留言在评论区。以下是运行结果。

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><title>百度地图API示例</title><script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=(这块儿连着括号一起换成在百度地图控制台申请的密钥)"></script><!-- 引入百度地图API --><style type="text/css">#map {width: 100%;height: 600px;margin: 0 auto;}.route {margin-bottom: 10px;}.route span {display: inline-block;width: 100px;text-align: right;margin-right: 10px;}</style><!-- 页面样式 --></head>
<body><div id="map"></div><!-- 地图展示容器 --><div id="result"></div><!-- 结果展示容器 --><script type="text/javascript">// 初始化地图var map = new BMap.Map("map");// 创建地图实例var point = new BMap.Point(121.571149, 38.920014); // 辽宁师范大学// 创建地图中心点坐标map.centerAndZoom(point, 12);// 设置地图中心点和缩放级别// 添加起点和终点var locations = [{ name: "辽宁师范大学", point: point },{ name: "大连市中山医院", point: new BMap.Point(121.655157, 38.922953) },{ name: "大连市第二人民医院", point: new BMap.Point(121.627698, 38.924042) },{ name: "大连医科大学附属第一医院", point: new BMap.Point(121.779814, 39.061763) },{ name: "大连市第七人民医院", point: new BMap.Point(121.529422, 38.881951) }];// 设置起点和终点的名称和坐标var startMarker = new BMap.Marker(point);// 创建起点标记map.addOverlay(startMarker);// 在地图上添加起点标记var startLabel = new BMap.Label("辽宁师范大学", { offset: new BMap.Size(20, -10) });// 设置起点标记的标签startMarker.setLabel(startLabel);// 在起点标记上添加标签locations.shift(); // 去除第一个元素,即起点// 移除数组中的第一个元素,即移除起点信息// 计算驾车时间calculateDrivingTime(locations).then(function(updatedLocations) {// 排序updatedLocations.sort(function(a, b) {return Math.ceil(a.time / 60) - Math.ceil(b.time / 60);});// 根据驾车时间进行排序updatedLocations.forEach(function(location) {var endMarker = new BMap.Marker(location.point);// 创建终点标记map.addOverlay(endMarker);// 在地图上添加终点标记var label = new BMap.Label(location.name, { offset: new BMap.Size(20, -10) });// 设置终点标记的标签endMarker.setLabel(label);// 在终点标记上添加标签var content = "<p>驾车路线:起点——辽宁师范大学,终点——" + location.name + ",时间:" + Math.ceil(location.time / 60) + "分钟,距离:" + Math.ceil(location.distance / 1000) + "公里</p>";// 构造结果的HTML内容document.getElementById("result").innerHTML += content;// 在结果容器中展示内容// 调整地图视野var bounds = new BMap.Bounds(point, location.point);// 创建视野范围对象map.setViewport(bounds);// 调整地图视野范围});}).catch(function(error) {console.log(error);});// 添加鼠标滚轮缩放地图的功能map.enableScrollWheelZoom();function calculateDrivingTime(locations) {// 计算驾车时间return new Promise(function(resolve, reject) {var updatedLocations = [];// 存储更新后的位置信息var count = 0;locations.forEach(function(location, index) {calculateDrivingRoute(point, location.point, function(result) {var time = result.time;var distance = result.distance;if (time !== undefined) {updatedLocations.push(Object.assign({}, location, { time: time, distance: distance }));}count++;if (count === locations.length) {resolve(updatedLocations);}});});});}function calculateDrivingRoute(startPoint, endPoint, callback) {// 计算驾车路线var driving = new BMap.DrivingRoute(map, {renderOptions: {map: map,autoViewport: false // 设置为false,不自动调整地图视野},onSearchComplete: function(result) {if (driving.getStatus() === BMAP_STATUS_SUCCESS) {var time = result.getPlan(0).getDuration(false);var distance = result.getPlan(0).getDistance(false);callback({ time: time, distance: distance });}}});driving.search(startPoint, endPoint);// 搜索驾车路线}</script>
</body>
</html>

这篇关于JS百度地图API开发:展示一起点多终点的驾车导航路线显示与时间计算,并按时间长短排列(超详细)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/weixin_57754287/article/details/134035002
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/669133

相关文章

使用Python实现base64字符串与图片互转的详细步骤

《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

Linux使用scp进行远程目录文件复制的详细步骤和示例

《Linux使用scp进行远程目录文件复制的详细步骤和示例》在Linux系统中,scp(安全复制协议)是一个使用SSH(安全外壳协议)进行文件和目录安全传输的命令,它允许在远程主机之间复制文件和目录,... 目录1. 什么是scp?2. 语法3. 示例示例 1: 复制本地目录到远程主机示例 2: 复制远程主

Python FastMCP构建MCP服务端与客户端的详细步骤

《PythonFastMCP构建MCP服务端与客户端的详细步骤》MCP(Multi-ClientProtocol)是一种用于构建可扩展服务的通信协议框架,本文将使用FastMCP搭建一个支持St... 目录简介环境准备服务端实现(server.py)客户端实现(client.py)运行效果扩展方向常见问题结

Spring Boot 整合 Apache Flink 的详细过程

《SpringBoot整合ApacheFlink的详细过程》ApacheFlink是一个高性能的分布式流处理框架,而SpringBoot提供了快速构建企业级应用的能力,下面给大家介绍Spri... 目录Spring Boot 整合 Apache Flink 教程一、背景与目标二、环境准备三、创建项目 & 添

RedisTemplate默认序列化方式显示中文乱码的解决

《RedisTemplate默认序列化方式显示中文乱码的解决》本文主要介绍了SpringDataRedis默认使用JdkSerializationRedisSerializer导致数据乱码,文中通过示... 目录1. 问题原因2. 解决方案3. 配置类示例4. 配置说明5. 使用示例6. 验证存储结果7.

Java进程CPU使用率过高排查步骤详细讲解

《Java进程CPU使用率过高排查步骤详细讲解》:本文主要介绍Java进程CPU使用率过高排查的相关资料,针对Java进程CPU使用率高的问题,我们可以遵循以下步骤进行排查和优化,文中通过代码介绍... 目录前言一、初步定位问题1.1 确认进程状态1.2 确定Java进程ID1.3 快速生成线程堆栈二、分析

Java中的登录技术保姆级详细教程

《Java中的登录技术保姆级详细教程》:本文主要介绍Java中登录技术保姆级详细教程的相关资料,在Java中我们可以使用各种技术和框架来实现这些功能,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录1.登录思路2.登录标记1.会话技术2.会话跟踪1.Cookie技术2.Session技术3.令牌技

Macos创建python虚拟环境的详细步骤教学

《Macos创建python虚拟环境的详细步骤教学》在macOS上创建Python虚拟环境主要通过Python内置的venv模块实现,也可使用第三方工具如virtualenv,下面小编来和大家简单聊聊... 目录一、使用 python 内置 venv 模块(推荐)二、使用 virtualenv(兼容旧版 P

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

Python实现一键PDF转Word(附完整代码及详细步骤)

《Python实现一键PDF转Word(附完整代码及详细步骤)》pdf2docx是一个基于Python的第三方库,专门用于将PDF文件转换为可编辑的Word文档,下面我们就来看看如何通过pdf2doc... 目录引言:为什么需要PDF转Word一、pdf2docx介绍1. pdf2docx 是什么2. by