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

效果如图:

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

实现步骤:

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...
相关推荐
华玥作者1 小时前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
Mr Xu_2 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠2 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
lang201509282 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
好家伙VCC3 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
未来之窗软件服务3 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
嘿起屁儿整3 小时前
面试点(网络层面)
前端·网络
VT.馒头4 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
phltxy5 小时前
Vue 核心特性实战指南:指令、样式绑定、计算属性与侦听器
前端·javascript·vue.js
Byron07075 小时前
Vue 中使用 Tiptap 富文本编辑器的完整指南
前端·javascript·vue.js