vue3 + 百度地图 实现多坐标生成轨迹的两种种方式

本次依然是关于百度地图中常见的一个问题,此次共使用了两种方式并做了一些分析及处理,希望有所帮助。如有问题可以评论或私信。

一、便捷方式

优点:便捷,所用的api方法是根据坐标进行计算后绘制路线,所以路线相对准确。

缺点:当坐标点多于10个之后,无法加载出来(即坐标过多无法使用)。

1.api文档

百度地图JSAPI 2.0类参考 (baidu.com)

2.部分代码(主要部分是driving.search中所传递的参数)

// start:起点坐标 end:终点坐标 way:途经点坐标数组
driving.search(start, end, {waypoints: way,
});

3.全部代码

function init() {// 地图初始化部分// DOM元素记得修改let map = new BMap.Map("allmap");// 初始化地图,设置中心点坐标和地图级别map.centerAndZoom(new BMap.Point(116.385306, 39.884902), 19)// 开启鼠标滚轮缩放map.enableScrollWheelZoom(true)// 初始化结束// 多个坐标(模拟数据)var path = [{ lng: 116.385306, lat: 39.884902 },{ lng: 116.408675, lat: 39.87078 },{ lng: 116.410723, lat: 39.868717 },{ lng: 116.412641, lat: 39.866834 },{ lng: 116.424907, lat: 39.863241 }];// 创建路线实例化var driving = new BMap.DrivingRouteLine(map, {renderOptions: {map: map}})// 设置起点、终点和途经点数组var start = new BMap.Point(path[0].lng, path[0].lat);var end = new BMap.Point(path[path.length - 1].lng, path[path.length - 1].lat);var way = []path.map((item, index) => {if (index != 0 && index != path.length - 1) {way.push(new BMap.Point(item.lng, item.lat))}})driving.search(start, end, {waypoints: way,});
}

二、复杂方式(由于最终使用了本方案,所以同时配备了弹框信息的处理)

优点:解决了点坐标过多问题

缺点:绘制路线准确度较差

1.实现思路,由于点坐标过多,或者说多的太多了,于是拿到坐标数组后,先添加点标记,然后两点标记之间连线。

如果点与点之间比较近或者说点比较密集可以使用此方法

2.代码

// 初始化地图
let BMap
let map = ref()
function init() {// 初始化内容省略BMap = window.BMap; map.value = new BMap.Map("allmap", { enableMapClick: false }); //初始显示map.value.centerAndZoom(new BMap.Point(103.388611, 35.563611), 5); // 添加滚轮效果map.value.enableScrollWheelZoom(true);// 模拟数据var path = [{ lng: 116.385306, lat: 39.884902 },{ lng: 116.408675, lat: 39.87078 },{ lng: 116.410723, lat: 39.868717 },{ lng: 116.412641, lat: 39.866834 },{ lng: 116.424907, lat: 39.863241 }];// 插入点坐标initData(path)
}// 初始化数据
function initData(data) {// 判断是否为空数组if (data.length > 0){var list = []var start = new BMap.Ponit(data[0].lng, data[0].lat)// 如果数组中的数据大于1个则绘制线路if (data.length != 1) {data.map((item, index) => {// 把途经点放入数组(即不是重点和起点的坐标)if (index != 0 && index != data.length - 1) {list.push(new BMap.Ponit(item.lng, item.lat)}})var end =new BMap.Ponit(data[data.length - 1].lng, data[data.length - 1].lat)// 绘制线路drawLine(start, end, list)}// 添加弹框和点标记addPopPoint(start, end, list)}
}// 绘制线路
function drawLine(start, end, list) {// 绘制线路所需要的参数为一个数组,所以又需要将三个参数放入一块var lineArr = []lineArr.push(start)if (list.length > 0) {list.map(item => {lineArr.push(item)})}lineArr.push(end)// 折线样式var sy = new BMap.Symbol(window.BMap_Symbol_SHAPE_BACKWARD_OPEN_ARROW, {scale: 0.6,// 图标缩放大小strokeColor: '#fff',// 设置矢量图标的线填充颜色strokeWeight: '2',// 设置线宽});var icons = new BMap.IconSequence(sy, '100%', '10%', false);var polyline = new BMap.Polyline(lineArr, {enableEditing: false,// 是否启用线编辑,默认为falseenableClicking: false,// 是否响应点击事件,默认为trueicons: [icons],strokeWeight: '6',// 折线的宽度,以像素为单位strokeOpacity: 0.8,// 折线的透明度,取值范围0 - 1strokeColor: "#18a45b" // 折线颜色});// 增加折线map.value.addOverlay(polyline);
}// 添加弹框和点标记
function addPopPoint(start, end, list) {// 修改可视范围数组var pointArr = []pointArr.push(start)// 弹框大小(可自己修改)var opts = {width: 250,height: 130,}// 起点终点弹框var startIcon = new BMap.Icon("http://api.map.baidu.com/images/dest_markers.png", new BMap.Size(32, 32), {anchor: new BMap.Size(18, 30)});var startMk = new BMap.Marker(start, { icon: startIcon });var startInfoWindow = new BMap.InfoWindow(`<p class="markContent">起点</p><p class="content">横坐标:${start.lng}</p><p class="content">纵坐标:${start.lat}</p>`, opts);startMk.addEventListener("click", function () {map.value.openInfoWindow(startInfoWindow, start); //开启信息窗口});map.value.addOverlay(startMk);if (end) {pointArr.push(end)var endIcon = new BMap.Icon("http://api.map.baidu.com/images/dest_markers.png", new BMap.Size(32, 32), {// 精灵图的偏移imageOffset: new BMap.Size(0, -32),anchor: new BMap.Size(15, 30)});var endMk = new BMap.Marker(end, { icon: endIcon });var endInfoWindow = new BMap.InfoWindow(`<p class="markContent">终点</p><p class="content">横坐标:${end.lng}</p><p class="content">纵坐标:${end.lat}</p>`, opts);endMk.addEventListener("click", function () {map.value.openInfoWindow(endInfoWindow, end); //开启信息窗口});map.value.addOverlay(endMk);mapList.map(item => {list.push(item)})list.push(end)}// 途经点弹框if (mapList.length > 0) {mapList.map((item, index) => {pointArr.push(item)var infoWindow = new BMap.InfoWindow(`<p class="markContent">途经点${index + 1}</p><p class="content"><p class="content">横坐标:${item.lng}</p><p class="content">纵坐标:${item.lat}</p>`, opts);var marker = new BMap.Marker(item)marker.addEventListener("click", function () {map.value.openInfoWindow(infoWindow, item); //开启信息窗口});map.value.addOverlay(marker)})}// 获取合适视野const view = map.value.getViewport(list);map.value.setViewport(view);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/41777.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CentOS修复OpenSSH漏洞升级到openssh 9.7 RPM更新包

在做政府和学校单位网站时&#xff0c;经常需要服务器扫描检测&#xff0c;经常被OpenSSH Server远程代码执行漏洞&#xff08;CVE-2024-6387&#xff09;安全风险通告&#xff0c;出了报告需要升级OpenSSH。 使用yum update openssh是无法更新到最新的&#xff0c;因为系统里的…

VS code修改底部的行号的状态栏颜色

VSCode截图 相信很多小伙伴被底部的蓝色状态栏困扰很久了 处理的方式有两种&#xff1a; 1、隐藏状态栏 2、修改其背景颜色 第一种方法大伙都会&#xff0c;今天就使用第二种方法。 1、点击齿轮进入setting 2、我现在用的新版本&#xff0c;设置不是以前那种json格式展示&…

17-JS封装:工具类方法

目录 一、extend方法 二、添加一些工具类方法&#xff1a;$.xxx() 实现1&#xff1a; 实现2&#xff1a; 一、extend方法 jQuery.fn.extend jQuery.extend function(...args){let target,source[];source[...args];//判断2种情况 //$.extend({}) -->给$添加属性//$.…

计算机提示由于找不到concrt140.dll怎么办,7种解决方法可以对比

在电脑中打开游戏或许软件出现找不到concrt140.dll无法继续执行代码怎么办&#xff1f;concrt140.dll是什么&#xff1f;丢失要怎么解决&#xff1f;下面给大家分析一下concrt140.dll文件是什么与concrt140.dll丢失的多种解决方法&#xff01;相信对你有帮助&#xff01; 一、c…

hdu物联网硬件实验2 GPIO亮灯

学院 班级 学号 姓名 日期 成绩 实验题目 GPIO亮灯 实验目的 点亮三个灯闪烁频率为一秒 硬件原理 无 关键代码及注释 const int ledPin1 GREEN_LED; // the number of the LED pin const int ledPin2 YELLOW_LED; const int ledPin3 RED…

FPGA开发笔试1

1. 流程简介 我是两天前有FPGA公司的HR来问我实习的事情&#xff0c;她当时问我距离能不能接受&#xff0c;不过确实距离有点远&#xff08;地铁通勤要将近一个半小时&#xff09;&#xff0c;然后她说给我约个时间&#xff0c;抽空做1个小时的题目&#xff08;线上做&#xf…

2024年【金属非金属矿山(地下矿山)安全管理人员】考试报名及金属非金属矿山(地下矿山)安全管理人员模拟考试题

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2024年金属非金属矿山&#xff08;地下矿山&#xff09;安全管理人员考试报名为正在备考金属非金属矿山&#xff08;地下矿山&#xff09;安全管理人员操作证的学员准备的理论考试专题&#xff0c;每个月更新的金属非…

CTF常用sql注入(三)无列名注入

0x06 无列名 适用于无法正确的查出结果&#xff0c;比如把information_schema给过滤了 join 联合 select * from users;select 1,2,3 union select * from users;列名被替换成了1,2,3&#xff0c; 我们再利用子查询和别名查 select 2 from (select 1,2,3 union select * f…

Go语言--工程管理、临时/永久设置GOPATH、main函数以及init函数

工作区 Go 代码必须放在工作区中。工作区其实就是一个对应于特定工程的目录&#xff0c;它应包含3个子目录:src 目录、pkg目录和bin 目录。 src 目录:用于以代码包的形式组织并保存 Go源码文件。(比如:.go.chs等)pkg 目录:用于存放经由 go install 命令构建安装后的代码包(包…

芯片基识 | 掰开揉碎讲 FIFO(同步FIFO和异步FIFO)

文章目录 一、什么是FIFO二、为什么要用FIFO三、什么时候用FIFO四、FIFO分类五、同步FIFO1. 同步FIFO电路框图2. 同步FIFO空满判断3. 同步FIFO设计代码4. 同步FIFO仿真结果 六、异步FIFO1、异步FIFO的电路框图2 、亚稳态3、打两拍4、格雷码5、如何判断异步FIFO的空满&#xff0…

react v18 less使用(craco)

方案一、弹出配置&#xff08;不推荐&#xff09; 安装依赖&#xff1a;yarn add less less-loader 首先 执行 yarn eject 弹出配置项文件&#xff08;注意&#xff1a;弹出配置不可逆&#xff01;&#xff09; 在 config 文件夹中 找到 webpack.config.js&#xff0c;在如图…

爆破片和安全阀

一、爆破片介绍 爆破片是一种用于安全释放压力的结构&#xff0c;通常应用于压力容器、管道和设备中&#xff0c;以防止由于压力过高而导致的灾难性故障。在压力超过设定值时&#xff0c;爆破片会破裂&#xff0c;从而迅速将过压泄放&#xff0c;保护设备和人员安全 爆破片通常…

java Web 优秀本科毕业论文系统用eclipse定制开发mysql数据库BS模式java编程jdbc

一、源码特点 JSP 优秀本科毕业论文系统是一套完善的web设计系统&#xff0c;对理解JSP java serlvet 编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,eclipse开发&#xff0c;数据库为Mysql5.0&a…

Selenium的这些自动化测试技巧你知道几个?

Selenium自动化测试技巧 与以前瀑布式开发模式不同&#xff0c;现在软件测试人员具有使用自动化工具执行测试用例套件的优势&#xff0c;而以前&#xff0c;测试人员习惯于通过测试脚本执行来完成测试。 但自动化测试的目的不是完全摆脱手动测试&#xff0c;而是最大程度地减少…

24.【C语言】getchar putchar的使用

1.基本作用 用户输入字符&#xff0c;getchar()获取字符&#xff08;含\n:即键入的Enter&#xff09;&#xff08;字符本质上是以ASCII值或EOF&#xff08;-1&#xff09;存储的&#xff09;&#xff08;与scanf有区别&#xff09; putchar() 打印字符&#xff08;把得到的A…

嵌入式系统中状态机实现详解

嵌入式开发中系统经常处于某种状态,如何处理呢?接下来分析一下,状态机的实现无非就是 3 个要素:状态、事件、响应。转换成具体的行为就 3 句话。 发生了什么事? 现在系统处在什么状态? 在这样的状态下发生了这样的事,系统要干什么? 用 C 语言实现状态机主要有 3 种方法…

LeetCode 60.排序排列(dfs暴力)

给出集合 [1,2,3,...,n]&#xff0c;其所有元素共有 n! 种排列。 按大小顺序列出所有排列情况&#xff0c;并一一标记&#xff0c;当 n 3 时, 所有排列如下&#xff1a; "123""132""213""231""312""321" 给定…

机器学习——岭回归

1、岭回归与线性回归的区别 岭回归&#xff08;Ridge Regression&#xff09;和线性回归&#xff08;Linear Regression&#xff09;都是用于回归分析的统计方法&#xff0c;但它们在处理方式和应用场景上有一些关键的区别&#xff1a; a)基本概念 线性回归&#xff1a;目标是…

在pycharm里如何使用Jetbrains AI Assistant

ai assistant激活成功后&#xff0c;如图 ai assistant渠道&#xff1a;https://web.52shizhan.cn/activity/ai-assistant 在去年五月份的 Google I/O 2023 上&#xff0c;Google 为 Android Studio 推出了 Studio Bot 功能&#xff0c;使用了谷歌编码基础模型 Codey,Codey 是…

ABAP 发送正文含图片邮件

背景&#xff1a; 客户要求系统发送的邮件内容中含logo图片 解决&#xff1a; 参考outlook中带图片的邮件&#xff0c;有两种形式&#xff0c;一种为url链接&#xff0c;需要点击下载才展示图片&#xff0c;一种为直接显示&#xff1b;如果使用ABAP发送该类型的邮件&#xff0…