1.提示:
同理可以做其他绘制
vite2.x+vue3安装忽略前面有安装介绍
https://editor.csdn.net/md/?articleId=120757440
vue3 百度地图和高德地图目前没有vue3的版本
百度地图提供了用链接方式做
https://lbsyun.baidu.com/index.php?title=jspopularGL/guide/helloworld
2.效果图
在index.html文件上添加百度地图
<script type="text/javascript" src="http://api.map.baidu.com/api?v=3.0&ak=你的密钥"></script>
<script type="text/javascript" src="//api.map.baidu.com/api?type=webgl&v=1.0&ak=你的密钥"></script>
<script type="text/javascript" src="//mapopen.cdn.bcebos.com/github/BMapGLLib/DrawingManager/src/DrawingManager.min.js"></script>
2.在.vue代码
<template>
<div class="">
<div>子级</div>
<div id="container" style="width: 100%;height: 500px"></div>
<ul class="drawing-panel">
<li class="bmap-btn bmap-marker" id="marker" @click="draw($event)"></li>
<li class="bmap-btn bmap-polyline" id="polyline" @click="draw($event)"></li>
<li class="bmap-btn bmap-rectangle" id="rectangle" @click="draw($event)"></li>
<li class="bmap-btn bmap-polygon" id="polygon" @click="draw($event)"></li>
<li class="bmap-btn bmap-circle" id="circle" @click="draw($event)"></li>
</ul>
</div>
</template>
<script>
export default {
data() {
return {
child: '子级',
map: '',
overlays: [],
polygonPath:[]
};
},
mounted() {
this.init();
},
methods: {
init() {
var map = new BMapGL.Map('container', { enableMapClick: false }); // 创建Map实例,GL版命名空间为BMapGL(鼠标右键控制倾斜角度)
map.centerAndZoom(new BMapGL.Point(116.404, 39.915), 15); // 初始化地图,设置中心点坐标和地图级别
map.enableScrollWheelZoom(true); // 开启鼠标滚轮缩放
this.map = map;
},
draw(e) {
var styleOptions = {
strokeColor: '#5E87DB', // 边线颜色
fillColor: '#5E87DB', // 填充颜色。当参数为空时,圆形没有填充颜色
strokeWeight: 2, // 边线宽度,以像素为单位
strokeOpacity: 1, // 边线透明度,取值范围0-1
fillOpacity: 0.2 // 填充透明度,取值范围0-1
};
var labelOptions = {
borderRadius: '2px',
background: '#FFFBCC',
border: '1px solid #E1E1E1',
color: '#703A04',
fontSize: '12px',
letterSpacing: '0',
padding: '5px'
};
// 实例化鼠标绘制工具
var drawingManager = new BMapGLLib.DrawingManager(this.map, {
// isOpen: true, // 是否开启绘制模式
enableCalculate: false, // 绘制是否进行测距测面
enableSorption: true, // 是否开启边界吸附功能
sorptiondistance: 20, // 边界吸附距离
circleOptions: styleOptions, // 圆的样式
polylineOptions: styleOptions, // 线的样式
polygonOptions: styleOptions, // 多边形的样式
rectangleOptions: styleOptions, // 矩形的样式
labelOptions: labelOptions // label样式
});
var arr = document.getElementsByClassName('bmap-btn');
for (var i = 0; i < arr.length; i++) {
arr[i].style.backgroundPositionY = '0';
}
e.currentTarget.style.backgroundPositionY = '-52px';
switch (e.currentTarget.id) {
case 'marker': {
var drawingType = BMAP_DRAWING_MARKER;
break;
}
case 'polyline': {
var drawingType = BMAP_DRAWING_POLYLINE;
break;
}
case 'rectangle': {
var drawingType = BMAP_DRAWING_RECTANGLE;
break;
}
case 'polygon': {
var drawingType = BMAP_DRAWING_POLYGON;
break;
}
case 'circle': {
var drawingType = BMAP_DRAWING_CIRCLE;
break;
}
}
// 进行绘制
if (drawingManager._isOpen && drawingManager.getDrawingMode() === drawingType) {
drawingManager.close();
} else {
drawingManager.setDrawingMode(drawingType);
drawingManager.open();
}
drawingManager.addEventListener('overlaycomplete', this.overlaycomplete);
},
//获坐标集
overlaycomplete(e) {
let self = this
//清除底层图案
//this.map.clearOverlays();
//画多边形
//this.clearData();
this.polygonPath = e.overlay.getPath(); //获取多边形路径点
//this.drawingManager.close();
//增加多边形,
//this.polygon = new BMap.Polygon(this.polygonPath, { strokeColor: 'red', strokeWeight: 1, strokeOpacity: 0.85 });
this.map.addOverlay(this.polygon);
//编辑多边形
//this.polygon.enableEditing();
console.log(this.polygonPath)
},
//清空坐标点
clearData() {
for (var i = 0; i < this.overlays.length; i++) {
this.map.removeOverlay(overlays[i]);
}
this.overlays.length = 0;
}
}
};
</script>
<style>
body,
html,
#container {
width: 100%;
height: 100%;
overflow: hidden;
margin: 0;
font-family: '微软雅黑';
}
ul li {
list-style: none;
}
.info {
z-index: 999;
width: auto;
min-width: 22rem;
padding: 0.75rem 1.25rem;
margin-left: 1.25rem;
position: fixed;
top: 1rem;
background-color: #fff;
border-radius: 0.25rem;
font-size: 14px;
color: #666;
box-shadow: 0 2px 6px 0 rgba(27, 142, 236, 0.5);
}
.drawing-panel {
z-index: 999;
position: fixed;
bottom: 3.5rem;
margin-left: 2.5rem;
padding-left: 0;
border-radius: 0.25rem;
height: 47px;
box-shadow: 0 2px 6px 0 rgba(27, 142, 236, 0.5);
}
.bmap-btn {
border-right: 1px solid #d2d2d2;
float: left;
width: 64px;
height: 100%;
background-image: url(//api.map.baidu.com/library/DrawingManager/1.4/src/bg_drawing_tool.png);
cursor: pointer;
}
.drawing-panel .bmap-marker {
background-position: -65px 0;
}
.drawing-panel .bmap-polyline {
background-position: -195px 0;
}
.drawing-panel .bmap-rectangle {
background-position: -325px 0;
}
.drawing-panel .bmap-polygon {
background-position: -260px 0;
}
.drawing-panel .bmap-circle {
background-position: -130px 0;
}
</style>
以上清除坐标html没写,可以自己在页面上添加