vite2.x+vue3 百度地图绘制

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没写,可以自己在页面上添加

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值