引入方式参考:百度地图离线地图实现绘制多边形及回显多边形区域_Holly31的博客-CSDN博客
红色编辑点:点击地图新增出来或者根据数据赋值过来,可拖拽或点击移动
ps:因为地图外层加了el-scrollbar,会干扰地图的缩放,所以自己写了个方法缩放
offlineMarke.vue
<template>
<div class="markmap">
<div :id="mapId" class="allmap" />
</div>
</template>
<script>
export default {
props: {
canAddMarker: {
type: Boolean,
default: false,
},
searchKeyword: String,
strokeColor: {
type: String,
default: "#2A8DFF",
},
path: {
type: String,
default:"",
},
markers: {
type: Array,
default:()=>[],
},
pcenter: {
type: Object,
default: () => ({
lng: 114.97731018066408,
lat: 25.8246784210205,
}),
},
},
components: {},
data() {
return {
markersOverlay:[],
mapId: "map" + new Date().getTime(),
zoom: 13,
center: {
lng: 114.97731018066408,
lat: 25.8246784210205,
},
};
},
watch: {
searchKeyword: {
handler(val) {
if (val) {
this.localSearchFun();
}
},
},
pcenter: {
handler(val) {
const point=new BMap.Point(val.lng,val.lat);
this.map.setCenter(point, );
},
},
markers: {
handler(arr) {
if(arr&&arr.length>0){
if(this.markersOverlay&&this.markersOverlay.length>0){
this.markersOverlay.forEach(item=>{
this.map.removeOverlay( item);
})
}
this.$nextTick(() => {
arr.forEach(item=>{
this.customMarkerOverlay(item);
})
},1000)
}
},
deep: true,
immediate:true
},
path: {
handler(val,oldVal) {
if (val) {
this.$nextTick(() => {
this.drawDefault(val);
}, 1000);
}
},
immediate: true,
deep: true,
},
},
computed: {
},
created() {
this.mapId = "map" + new Date().getTime();
},
mounted() {
this.initMap();
},
methods: {
//默认多边形
drawDefault(points) {
if (points) {
let newPonits = [];
let arr = points.split(";");
arr.forEach((item) => {
let itemArr = item.split(",");
newPonits.push(new BMap.Point(itemArr[0], itemArr[1]));
});
const polygon = new BMap.Polygon(newPonits, {
strokeColor: this.strokeColor,
strokeWeight: 4,
strokeOpacity: 1,
fillColor: this.strokeColor,
fillOpacity: 0.2,
});
this.map.removeOverlay(this.polygonOverlay);
this.map.addOverlay(polygon);
this.map.setCenter(newPonits[0]);
this.polygonOverlay=polygon;
}
},
//地图初始化
initMap() {
const _this = this;
const point = new BMap.Point(114.97731018066408, 25.8246784210205);
_this.map = new BMap.Map(this.mapId, { enableMapClick: false,minZoom:4,maxZoom:19 }); // 创建Map实例,GL版命名空间为BMap(鼠标右键控制倾斜角度)
_this.map.centerAndZoom(point, this.zoom); // 初始化地图,设置中心点坐标和地图级别
/* _this.map.enableScrollWheelZoom(true); */ // 开启鼠标滚轮缩放
_this.suofang();
/* _this.cerateMarker(point); */
this.map.addControl(new BMap.NavigationControl({anchor:BMAP_ANCHOR_BOTTOM_LEFT}));//type:BMAP_NAVIGATION_CONTROL_ZOOM type:BMAP_NAVIGATION_CONTROL_SMALL,enableGeolocation:true
this.map.addControl(new BMap.GeolocationControl({anchor:BMAP_ANCHOR_BOTTOM_RIGHT}));
this.map.addEventListener("click", function (e) {
_this.mapClickFun(e);
});
},
/* 标记点 */
createMarkerDOM(markerObj) {
const img = document.createElement("img");
img.style.height = "50px";
img.style.width = "50px";
img.src = markerObj.src;
img.draggable = markerObj.dragging;
return img;
},
customMarkerOverlay(markerObj) {
const _this=this;
let myIcon = new BMap.Icon(markerObj.icon, new BMap.Size(45, 45));
let pt = new BMap.Point(markerObj.lng, markerObj.lat);
var marker = new BMap.Marker(pt, {
icon: myIcon,
enableDragging: markerObj.dragging,
oType:'marker',
offset:markerObj.offset?new BMap.Size(...markerObj.offset):new BMap.Size(5,-17)
});
this.map.addOverlay(marker);
this.markersOverlay.push(marker);
// 绑定点击事件
marker.addEventListener("click", function (e) {
console.log("eeee", e);
});
//绑定拖拽事件
marker.addEventListener("dragend", function (e) {
_this.$emit("updateMarkerLocal", e.point);
});
},
cerateMarker(point) {
const marker = new BMap.Marker(point);
// 将标记点添加到地图上
this.map.addOverlay(marker);
},
handlerMap({ BMap, map }) {
this.BMap = BMap;
this.map = map;
},
//点击地图事件 增加标记点
mapClickFun(ev) {
if (this.canAddMarker) {
this.$emit("updateMarkerLocal", ev.point);
}
},
//缩放
suofang() {
document.querySelector(".markmap").onmousewheel = (e) => {
e = e || window.event;
if (e.stopPropagation) {
//这是取消冒泡
e.stopPropagation();
} else {
e.cancelBubble = true;
}
if (e.preventDefault) {
//这是取消默认行为,要弄清楚取消默认行为和冒泡不是一回事
e.preventDefault();
} else {
e.returnValue = false;
}
//放大 getZoom返回地图当前缩放级别
if (e.wheelDelta > 0) {
this.zoom = this.zoom + 1;
if (this.zoom > 19) {
this.zoom=19;
}
}
//缩小
if (e.wheelDelta < 0) {
e.cancelBubble = true;
this.zoom = this.zoom - 1;
if (this.zoom < 4) {
this.zoom = 4;
}
}
this.map.setZoom(this.zoom);
};
},
//拖拽标记
markerDragendEvent(e) {
const _this = this;
_this.$emit("updateMarkerLocal", e.point);
},
//关键词搜索
localSearchFun(searchWord) {
const _this = this;
this.$nextTick(() => {
const local = new BMap.LocalSearch(this.map, {
onSearchComplete: function (e) {
_this.$emit("searchcomplete", e);
},
});
local.search(searchWord ? searchWord : this.searchKeyword);
});
},
},
};
</script>
<style lang="scss" scoped>
.markmap {
width: 800px;
height: 500px;
.allmap {
width: 100%;
height: 100%;
}
}
</style>
页面使用
<template>
<div class="">
<offlineMarke
ref="mydrawMap"
class="mymap-wrap"
:canAddMarker="canAddMarker"
:path="path"
:strokeColor="strokeColor"
:pcenter="center"
:markers="markers"
@updateMarkerLocal="updateMarkerLocal"
></offlineMarke>
</div>
</template>
<script>
import offlineMarke from "@/components/Map/offlineMarke";
export default {
props: [],
components: { offlineMarke },
data() {
return {
canAddMarker: true,
strokeColor: "#FF6B36",
center:{
lng: "114.933625",
lat: "25.85190",
},
path: "114.92785540582945,25.83652466645269;114.92823026067752,25.847650021588933;114.93326455552047,25.84679557530646;114.94444120792562,25.847283346808027;114.94666935084885,25.846470393187857;114.94991319176417,25.844372292159633;114.9536417373817,25.840323628122093;114.95646285382479,25.83860005841268;114.96159150781574,25.83115605191992;114.96356808621543,25.824976622119365;114.9643227797862,25.82133385975571;114.9613758810813,25.81834150683285;114.9581414800636,25.816454984607688;114.95318206516998,25.81499128286883;114.950630482145,25.813495035728792;114.94502418704789,25.80816043559642;114.93953141347649,25.80412817087722;114.93648047520966,25.807707561717777;114.94762118982572,25.816164775470398;114.93985862738357,25.82410099603871;114.94194301915044,25.826117491923867;114.94172739241593,25.839321438580683;114.93834924024202,25.839256398119232;114.92785540582945,25.83652466645269",
markers: [
{
lng: "114.933625",
lat: "25.85190",
icon: "",
},
{
lat: "25.826759824838696",
lng: "114.94770203106496",
dragging: true,
icon: "",
offset: [3, -18],
},
],
};
},
created() {},
mounted() {},
methods: {
updateMarkerLocal(point) {
this.markers[1].lat=point.lat;
this.markers[1].lng=point.lng;
},
},
};
</script>
<style lang="scss" scoped>
</style>