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开发:展示一起点多终点的驾车导航路线显示与时间计算,并按时间长短排列(超详细)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/669133

相关文章

IntelliJ IDEA 中配置 Spring MVC 环境的详细步骤及问题解决

《IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决》:本文主要介绍IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决,本文分步骤结合实例给大... 目录步骤 1:创建 Maven Web 项目步骤 2:添加 Spring MVC 依赖1、保存后执行2、将新的依赖

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

Python的time模块一些常用功能(各种与时间相关的函数)

《Python的time模块一些常用功能(各种与时间相关的函数)》Python的time模块提供了各种与时间相关的函数,包括获取当前时间、处理时间间隔、执行时间测量等,:本文主要介绍Python的... 目录1. 获取当前时间2. 时间格式化3. 延时执行4. 时间戳运算5. 计算代码执行时间6. 转换为指

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

如何为Yarn配置国内源的详细教程

《如何为Yarn配置国内源的详细教程》在使用Yarn进行项目开发时,由于网络原因,直接使用官方源可能会导致下载速度慢或连接失败,配置国内源可以显著提高包的下载速度和稳定性,本文将详细介绍如何为Yarn... 目录一、查询当前使用的镜像源二、设置国内源1. 设置为淘宝镜像源2. 设置为其他国内源三、还原为官方

最详细安装 PostgreSQL方法及常见问题解决

《最详细安装PostgreSQL方法及常见问题解决》:本文主要介绍最详细安装PostgreSQL方法及常见问题解决,介绍了在Windows系统上安装PostgreSQL及Linux系统上安装Po... 目录一、在 Windows 系统上安装 PostgreSQL1. 下载 PostgreSQL 安装包2.

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

python中各种常见文件的读写操作与类型转换详细指南

《python中各种常见文件的读写操作与类型转换详细指南》这篇文章主要为大家详细介绍了python中各种常见文件(txt,xls,csv,sql,二进制文件)的读写操作与类型转换,感兴趣的小伙伴可以跟... 目录1.文件txt读写标准用法1.1写入文件1.2读取文件2. 二进制文件读取3. 大文件读取3.1

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

如何在Mac上安装并配置JDK环境变量详细步骤

《如何在Mac上安装并配置JDK环境变量详细步骤》:本文主要介绍如何在Mac上安装并配置JDK环境变量详细步骤,包括下载JDK、安装JDK、配置环境变量、验证JDK配置以及可选地设置PowerSh... 目录步骤 1:下载JDK步骤 2:安装JDK步骤 3:配置环境变量1. 编辑~/.zshrc(对于zsh