本次依然是关于百度地图中常见的一个问题,此次共使用了两种方式并做了一些分析及处理,希望有所帮助。如有问题可以评论或私信。
一、便捷方式
优点:便捷,所用的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);
}