使用echarts的bmap配置项绘制区域轮廓遮罩

示例图

代码

vue 复制代码
<template>
  <div id="map" style="width: 100%; height: 100vh"></div>
</template>

<script>
import * as echarts from "echarts";
import "echarts/extension/bmap/bmap";
export default {
  data() {
    return {
      mapOptions: {
        bmap: {
          roam: true, // 是否开启拖拽和缩放
          center: [116.403414, 39.924091], // 地图中心点坐标
          zoom: 15, // 缩放级别
        },
        series: [
          {
            type: "scatter",
            coordinateSystem: "bmap",
            symbolSize: 20,
          },
        ],
      },
    };
  },
  mounted() {
    this.init();
  },
  methods: {
    init() {
      // 初始化百度地图
      var myChart = echarts.init(document.getElementById("map"));
      myChart.setOption(this.mapOptions);
      var map = myChart.getModel().getComponent("bmap").getBMap();
      map.setMinZoom(9);
      map.setMaxZoom(22);
      var boundary = new BMap.Boundary();
      boundary.get("北京市", (rs) => {
        let count = rs.boundaries.length;
        if (count === 0) {
          alert("未能获取当前行政区域");
          return;
        }
        const EN_JW = "180, 90;";
        const NW_JW = "-180,  90;";
        const WS_JW = "-180, -90;";
        const SE_JW = "180, -90;";
        var points = rs.boundaries[0];
        // 东南西北四个角添加一个覆盖物
        const ply1 = new BMap.Polygon(
          points + SE_JW + SE_JW + WS_JW + NW_JW + EN_JW + SE_JW,
          {
            strokeColor: "none",
            fillColor: "#fff",
            fillOpacity: 0.9,
            strokeOpacity: 1,
          }
        );
        map.addOverlay(ply1);
        // 绘制北京市整体的外轮廓
        for (let i = 0; i < count; i++) {
          const ply = new BMap.Polygon(points, {
            strokeWeight: 2,
            strokeColor: "#2457ff",
            fillColor: "transparent",
          });
          map.addOverlay(ply);
        }
      });
    },
  },
};
</script>

<style></style>

参考文章
百度地图api只显示某个省市的行政区域
Echarts中使用bmap作为底图,添加行政划区遮罩层

相关推荐
Moment8 小时前
Vibe Coding 时代,到底该选什么样的工具来提升效率❓❓❓
前端·后端·github
IT_陈寒10 小时前
SpringBoot性能飙升200%?这5个隐藏配置你必须知道!
前端·人工智能·后端
小时前端10 小时前
React性能优化的完整方法论,附赠大厂面试通关技巧
前端·react.js
Nicko11 小时前
Jetpack Compose BOM 2026.02.01 解读与升级指南
前端
小蜜蜂dry11 小时前
nestjs学习 - 控制器、提供者、模块
前端·node.js·nestjs
优秀稳妥的JiaJi11 小时前
基于腾讯地图实现电子围栏绘制与校验
前端·vue.js·前端框架
前端开发呀11 小时前
从 qiankun(乾坤) 迁移到 Module Federation(模块联邦),对MF只能说相见恨晚!
前端
Lee川11 小时前
深度解构JavaScript:作用域链与闭包的内存全景图
javascript·面试
没想好d12 小时前
通用管理后台组件库-10-表单组件
前端
恋猫de小郭12 小时前
你用的 Claude 可能是虚假 Claude ,论文数据告诉你,Shadow API 中的欺骗性模型声明
前端·人工智能·ai编程