vue高德地图点聚合

遇到的问题:

因为需要展示渔船估计,因为早期渔船上面的GPS是10分钟上传一个经纬度点,所以在地图上展示经纬度点非常多,显得非常密集。解决这些密集点的办法就是通过点聚合来做。
点聚合: 可以在不同的地图缩放级别对海量的数据点进行聚合展示,点聚合插件可以支持10万个点,性能良好。
官方文档
未做聚合之前(此为测试数据,GPS在陆地上):
在这里插入图片描述

以下开始使用点聚合尝试一下:

在这里插入图片描述
点聚合代码

   var _renderClusterMarker = function(context) {
        var div = document.createElement('div')
        var size = 10
        div.style.backgroundColor = '#ffffff'
        div.style.width = div.style.height = size + 'px'
        div.style.border = 'solid red 2px'
        div.style.borderRadius = size / 2 + 'px'
        context.marker.setOffset(new AMap.Pixel(-size / 2, -size / 2))
        context.marker.setContent(div)
      }
      const that = this
      this.map.plugin(['AMap.MarkerClusterer'], function() {
        that.cluster = new AMap.MarkerClusterer(
          that.map, // 地图实例
          that.markerArray, // 海量点组成的数组
          {
            gridSize: 30,
            zIndex: 2,
            zoomOnClick: false,
            renderClusterMarker: _renderClusterMarker
          })
      })

聚合点的点击事件

     this.cluster.on('click', (cluster, lnglat, target, markers) => {
       console.log(cluster.lnglat.lat)
      }
      )

聚合后的效果:
缩小后只剩两个点
在这里插入图片描述
接着放大,点变多
在这里插入图片描述
聚合后的坏处:
的确随着地图的放大、缩小可以展示不同数量的经纬度点,本项目的经纬度点可以点击展示经纬度信息、渔船信息等,但是采用点聚合后的经纬度不再是渔船GPS真正上传的经纬度,而是周边gridSize范围内的点聚合的结果。当然如果不是需要准确的点,采用点聚合效果还是非常理想的~

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要在Vue3中使用高德地图聚合图,可以按照以下步骤进行: 1. 安装高德地图的JavaScript API ```html <script src="https://webapi.amap.com/maps?v=1.4.15&key=您申请的key值"></script> ``` 2. 在Vue3项目中安装`vue-amap`插件 ```bash npm install vue-amap --save ``` 3. 在`main.js`中引入`vue-amap`插件,并进行配置 ```javascript import VueAMap from 'vue-amap'; Vue.use(VueAMap); VueAMap.initAMapApiLoader({ key: '您申请的key值', plugin: ['AMap.MarkerClusterer'], v: '1.4.15', }); ``` 4. 在Vue3组件中使用高德地图聚合图 ```vue <template> <div> <el-amap :zoom="zoom" :center="center"> <el-amap-marker-clusterer :grid-size="80" :render-clusters="renderClusters"> <el-amap-marker v-for="(item, index) in markers" :key="index" :position="item.position" :ext-data="item"></el-amap-marker> </el-amap-marker-clusterer> </el-amap> </div> </template> <script> export default { data() { return { zoom: 11, center: [116.397428, 39.90923], markers: [ { position: [116.403981, 39.915599] }, { position: [116.398764, 39.914888] }, { position: [116.390786, 39.912356] }, { position: [116.416357, 39.928353] }, { position: [116.368904, 39.913423] }, ], }; }, methods: { renderClusters(data) { return data.map((item) => { return { ...item, icon: new AMap.Icon({ size: new AMap.Size(32, 32), image: 'https://a.amap.com/jsapi_demos/static/images/marker.png', imageSize: new AMap.Size(32, 32), }), }; }); }, }, }; </script> ``` 这样就可以在Vue3项目中使用高德地图聚合图了。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值