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

相关文章

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

Python中isinstance()函数原理解释及详细用法示例

《Python中isinstance()函数原理解释及详细用法示例》isinstance()是Python内置的一个非常有用的函数,用于检查一个对象是否属于指定的类型或类型元组中的某一个类型,它是Py... 目录python中isinstance()函数原理解释及详细用法指南一、isinstance()函数

Python的pandas库基础知识超详细教程

《Python的pandas库基础知识超详细教程》Pandas是Python数据处理核心库,提供Series和DataFrame结构,支持CSV/Excel/SQL等数据源导入及清洗、合并、统计等功能... 目录一、配置环境二、序列和数据表2.1 初始化2.2  获取数值2.3 获取索引2.4 索引取内容2

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

在Node.js中使用.env文件管理环境变量的全过程

《在Node.js中使用.env文件管理环境变量的全过程》Node.js应用程序通常依赖于环境变量来管理敏感信息或配置设置,.env文件已经成为一种流行的本地管理这些变量的方法,本文将探讨.env文件... 目录引言为什么使php用 .env 文件 ?如何在 Node.js 中使用 .env 文件最佳实践引

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

Python屏幕抓取和录制的详细代码示例

《Python屏幕抓取和录制的详细代码示例》随着现代计算机性能的提高和网络速度的加快,越来越多的用户需要对他们的屏幕进行录制,:本文主要介绍Python屏幕抓取和录制的相关资料,需要的朋友可以参考... 目录一、常用 python 屏幕抓取库二、pyautogui 截屏示例三、mss 高性能截图四、Pill

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

C#实现SHP文件读取与地图显示的完整教程

《C#实现SHP文件读取与地图显示的完整教程》在地理信息系统(GIS)开发中,SHP文件是一种常见的矢量数据格式,本文将详细介绍如何使用C#读取SHP文件并实现地图显示功能,包括坐标转换、图形渲染、平... 目录概述功能特点核心代码解析1. 文件读取与初始化2. 坐标转换3. 图形绘制4. 地图交互功能缩放