使用高德地图实现点聚合效果

效果如图:

实现的是一个简单的点聚合效果,没有多余的操作,只有单纯的展示效果。

实现步骤:

1.需要准备高德地图的开放平台的web端的key和密钥

申请时选择web端(JS API)

申请完成后得到key和密钥

2.代码

1、安装依赖 需要下载高德地图依赖 @amap/amap-jsapi-loader

js 复制代码
npm i @amap/amap-jsapi-loader --save

2、密钥配置 在main.js 或其他地方(index.html、App.vue)中设置密钥(必须有这步,不然后面地图会有问题)

js 复制代码
window._AMapSecurityConfig = {
  securityJsCode: '5b4512cb80ccef95b131f479d0ee46aa',
};

3、地图显示

js 复制代码
<template>
    <div>
       <div id="mapContainer"></div>
    </div>
</template>
export default {
   data() {
      return {
        map: null, //地图实例
        userList: [], // 数据列表
        cluster: null, // 点聚合信息
     };
  },
  mounted() {
    this.initMap();
  },
  methods: {
      // 初始化地图
      async initMap() {
          let that = this;
          // 引入插件
          let AMapLoader;
          try {
            AMapLoader = await import("@amap/amap-jsapi-loader");
          } catch (error) {
            that.$modal.msgWarning("地图初始化失败,请重新加载");
          }
          AMapLoader.load({
            key: "填写申请你的申请的key", //
            version: "2.0", // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15
            plugins: [
              "AMap.ToolBar", // 缩放按钮
              "AMap.Scale", // 比例尺
              "AMap.DragRoute", // 拖拽点图
              "AMap.Driving", // 导航
              "AMap.MarkerCluster", // 点聚合
            ],
          }).then((map)=>{
              AMap = map;
              that.map = new AMap.Map("mapContainer", {
                center: [116.394718, 39.90923], // 中心点
                zoom: 5,  // 缩放比例
              });
              that.map.addControl(new AMap.ToolBar());
              that.map.addControl(new AMap.Scale());
              // 获取数据
              that.handleQuery();
          })
      },
      
      handleQuery(){
        //通过请求获取数据
         getUserList().then((res) => {
             this.userList = res.data.map((v) => ({
                 weight: 1,
                 lnglat: [v.lng, v.lat],
             }));
             this.cluster = new AMap.MarkerCluster(
                this.map, // 地图实例
                this.userList, // 海量点数据,数据中需包含经纬度信息字段 lnglat
                {
                  gridSize: 30,
                }
             );
         })
      }
  }
}

注意点:

  1. 地图容器:需要明确宽高,设置宽高,否则高度没有的话地图时不能正常显示。
  2. userList数据,数据格式,里面的lnglat需要正确放置经纬度数据
js 复制代码
[
    {weight: 1, lnglat: [114.3, 35.6]},
    {weight: 1, lnglat: [114.3, 35.6]},
    {weight: 1, lnglat: [114.3, 35.6]},
    {weight: 1, lnglat: [114.3, 35.6]},
]
  1. 还可以设置,如聚合后的点,和未聚合的点样式、事件等。更多配置请参考官方文档:lbs.amap.com/api/javascr...
相关推荐
天外来物几秒前
实战分享:用CI/CD实现持续部署
前端·nginx·docker
moxiaoran57532 分钟前
Spring Cloud Gateway 动态路由实现方案
运维·服务器·前端
市民中心的蟋蟀2 分钟前
第十一章 这三个全局状态管理库之间的共性与差异 【上】
前端·javascript·react.js
vvilkim16 分钟前
Flutter 常用组件详解:Text、Button、Image、ListView 和 GridView
前端·flutter
vvilkim22 分钟前
Flutter 命名路由与参数传递完全指南
前端·flutter
NA23 分钟前
redis
前端
你真好看_23 分钟前
6年低代码 零代码 系统二开人员的角度,看低代码 到底有多好用!!!
前端
JC_You_Know31 分钟前
边缘计算一:现代前端架构演进图谱 —— 从 SPA 到边缘渲染
前端·人工智能·边缘计算
DoraBigHead33 分钟前
深入 JavaScript 作用域机制:透视 V8 引擎背后的执行秘密
前端·javascript
Tu_Jipang35 分钟前
前端从零搭建企业级后台系统实战指南
前端