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

效果如图:

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

实现步骤:

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...
相关推荐
niucloud-admin4 小时前
web 端前端
前端
胖者是谁7 小时前
EasyPlayerPro的使用方法
前端·javascript·css
EndingCoder7 小时前
索引类型和 keyof 操作符
linux·运维·前端·javascript·ubuntu·typescript
liux35287 小时前
Web集群管理实战指南:从架构到运维
运维·前端·架构
沛沛老爹7 小时前
Web转AI架构篇 Agent Skills vs MCP:工具箱与标准接口的本质区别
java·开发语言·前端·人工智能·架构·企业开发
小光学长8 小时前
基于Web的长江游轮公共服务系统j225o57w(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库
Joe5569 小时前
vue2 + antDesign 下拉框限制只能选择2个
服务器·前端·javascript
ChangYan.9 小时前
monorepo 多包管理识别不到新增模块,解决办法
前端·chrome
Jinuss9 小时前
React元素创建介绍
前端·react.js
济61710 小时前
linux 系统移植(第六期)--Uboot移植(5)--bootcmd 和 bootargs 环境变量-- Ubuntu20.04
java·前端·javascript