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,// 是否启用线编辑,默认为false
        enableClicking: false,// 是否响应点击事件,默认为true
        icons: [icons],
        strokeWeight: '6',// 折线的宽度,以像素为单位
        strokeOpacity: 0.8,// 折线的透明度,取值范围0 - 1
        strokeColor: "#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.mfbz.cn/a/777578.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

制定事件响应计划的四个关键步骤,如何做到风险闭环

一个有效的安全事件响应策略的关键组成部分有哪些&#xff1f;一个有效的安全事件响应策略包括四个关键组成部分&#xff0c;它们协同工作以确保对网络安全问题的快速和有效响应。 一个有效的安全事件响应策略的关键组成部分有哪些&#xff1f; 一个有效的安全事件响应策略包括…

Java常用算法集合扩容机制分析

基础篇 基础篇要点&#xff1a;算法、数据结构、基础设计模式 1. 二分查找 要求 能够用自己语言描述二分查找算法能够手写二分查找代码能够解答一些变化后的考法 算法描述 前提&#xff1a;有已排序数组 A&#xff08;假设已经做好&#xff09; 定义左边界 L、右边界 R&…

SQLite 命令行客户端 + Windows 批处理应用

SQLite 命令行客户端 Windows 批处理应用 下载 SQLite 客户端1. Bat 辅助脚本1. 执行SQL.bat执行 2. 导出Excel.bat执行效果 3. 导出HTML.bat执行效果 4. 清空-订单表.bat 2. 测试 SQL1. 创建订单表.sql2. 插入订单表.sql3. 查询订单表.sql4. 清空订单表.sql5. 删除订单表.sql…

linux驱动编程 - kfifo先进先出队列

简介&#xff1a; kfifo是Linux Kernel里面的一个 FIFO&#xff08;先进先出&#xff09;数据结构&#xff0c;它采用环形循环队列的数据结构来实现&#xff0c;提供一个无边界的字节流服务&#xff0c;并且使用并行无锁编程技术&#xff0c;即当它用于只有一个入队线程和一个出…

黑马的ES课程中的不足

在我自己做项目使用ES的时候&#xff0c;发现了黑马没教的方法&#xff0c;以及一些它项目的小问题 搜索时的匹配方法 这个boolQuery().should 我的项目是通过文章的标题title和内容content来进行搜索 但是黑马它的项目只用了must 如果我们的title和content都用must&#x…

Arc for Windows 无法使用?一篇文章教会你!

&#x1f44b; 大家好&#xff0c;我是 Beast Cheng &#x1f4eb; 联系我&#xff1a;458290771qq.com &#x1f331; 接合作、推广…… 什么是Arc浏览器&#xff1f; Arc浏览器是The Browser Conpany使用Swift语言开发的一款浏览器&#xff0c;Arc浏览器由其漂亮的侧边栏闻名…

HTML5使用<mark>标签:高亮显示文本

1、<mark>标签的使用 mark 标签用于表示页面中需要突出显示或高亮的一段文本&#xff0c;这段文本对于当前用户具有参考作用。它通常在引用原文以引起读者注意时使用。<mark>标签的作用相当于使用一支荧光笔在打印的纸张上标出一些文字。它与强调不同&#xff0c;…

自闭症在生活中的典型表现

自闭症&#xff0c;这个看似遥远却又悄然存在于我们周围的疾病&#xff0c;其影响深远且复杂。在日常生活中&#xff0c;自闭症患者的典型表现往往让人印象深刻&#xff0c;这些表现不仅揭示了他们内心的世界&#xff0c;也提醒我们要以更加包容和理解的心态去面对他们。 首先…

UEC++ 虚幻5第三人称射击游戏(二)

UEC++ 虚幻5第三人称射击游戏(二) 派生榴弹类武器 新建一个继承自Weapon的子类作为派生榴弹类武器 将Weapon类中的Fire函数添加virtual关键字变为虚函数让榴弹类继承重写 在ProjectileWeapon中重写Fire函数,新建生成投射物的模版变量 Fire函数重写逻辑 代码//生成的投射物U…

MySQL中mycat与mha应用

目录 一.Mycat代理服务器 1.Mycat应用场景 2.mycat安装目录结构说明 3.Mycat的常用配置文件 4.Mycat日志 5.mycat 实现读写分离 二.MySQL高可用 1.原理过程 2.MHA软件 3.实现MHA 一.Mycat代理服务器 1.Mycat应用场景 Mycat适用的场景很丰富&#xff0c;以下是几个典型…

大模型的实践应用25-LLama3模型模型的架构原理,以及手把手教你搭建LLama3模型

大家好,我是微学AI,今天给大家介绍一下大模型的实践应用25-LLama3模型模型的架构原理,以及手把手教你搭建LLama3模型。LLaMA 3 是Meta公司开发的最新一代大规模语言模型,其架构在很大程度上继承了LLaMA 2的设计,但对某些关键组件进行了改进和优化。 文章目录 一、LLama3模…

Vue通过Key管理状态

Vue通过Key管理状态 Vue 默认按照“就地更新”的策略来更新&#xff0c;通过 v-for 渲染的元素列表。当数据项的顺序改变时&#xff0c;Vue 不会随之移动 DOM 元素的顺序&#xff0c;而是就地更新每个元素&#xff0c;确保它们在原本指定的索引位置上渲染。为了给 Vue 一个提示…

mupdf加载PDF显示中文乱码

现象 加载PDF显示乱码,提示非嵌入字体 non-embedded font using identity encoding调式 在pdf-font.c中加载字体 调试源码发现pdf文档的字体名字居然是GBK&#xff0c;估计又是哪个windows下写的pdf生成工具生成pdf 字体方法&#xff1a; static pdf_font_desc * load_cid…

STM32利用FreeRTOS实现4个led灯同时以不同的频率闪烁

在没有接触到FreeRTOS时&#xff0c;也没有想过同时叫两个或两个以上的led灯闪烁的想法&#xff0c;接触后&#xff0c;发现如果想叫两个灯同时以不同的频率闪烁&#xff0c;不能说是不可能&#xff0c;就算是做到了也要非常的麻烦。但是学习了FreeRTOS后&#xff0c;发现要想同…

Qt 网络编程实战

一.获取主机的网络信息 需要添加network模块 QT core gui network主要涉及的类分析 QHostInfo类 QHostInfo::localHostName() 获取本地的主机名QHostInfo::fromName(const QString &) 获取指定主机的主机信息 addresses接口 QNetworkInterface类 QNetworkInterfac…

Redis---9---集群(cluster)

将新增的6387节点&#xff08;空槽号&#xff09;作为master节点加入原集群 Redis—9—集群&#xff08;cluster&#xff09; 是什么 定义 ​ 由于数据量过大&#xff0c;单个Master复制集难以承担&#xff0c;因此需要对多个复制集进行集群&#xff0c;形成水平扩展每个复…

电脑f盘的数据回收站清空了能恢复吗

随着信息技术的飞速发展&#xff0c;电脑已成为我们日常生活和工作中不可或缺的设备。然而&#xff0c;数据的丢失或误删往往会给人们带来极大的困扰。尤其是当F盘的数据在回收站被清空后&#xff0c;许多人会陷入绝望&#xff0c;认为这些数据已无法挽回。但事实真的如此吗&am…

【C语言】自定义类型:联合和枚举

前言 前面我们学习了一种自定义类型&#xff0c;结构体&#xff0c;现在我们学习另外两种自定义类型&#xff0c;联合 和 枚举。 目录 一、联合体 1. 联合体类型的声明 2. 联合体的特点 3. 相同成员联合体和结构体对比 4. 联合体大小的计算 5. 用联合体判断当前机…

AI Earth应用—— 在线使用sentinel数据VV和VH波段进行水体提取分析(昆明抚仙湖、滇池为例)

AI Earth 本文的主要目的就是对水体进行提取,这里,具体的操作步骤很简单基本上是通过,首页的数据检索,选择需要研究的区域,然后选择工具箱种的水体提取分析即可,剩下的就交给阿里云去处理,结果如下: 这是我所选取的一景影像: 详情 卫星: Sentinel-1 级别: 1 …