vue中使用高德地图自定义行政区划聚合

 先看实现效果(上传图片说是违规,我也不知道为啥,所以就把图片删了):

找了很多,都直接是官方的数据,反复查看官方文档,终于完美解决。如果能够帮到你,欢迎大家点赞收藏加关注,多多交流,互相学习,共同进步!!!!

直接上代码: 

<template>
    <div id="map_index"></div>
</template>
<script>
export default {
    name:"ditu",
    data(){
        return{
            amap:null,
            zoom:4,
            pointData:[],
        }
    },
    methods: {
        getAMap(){
            let map = new AMap.Map('map_index', {
                resizeEnable: true,
                zoom: this.zoom,
                center: [104.676809,37.290981],
            });
            this.amap = map
            this.loadDistrictCluster();
        },
        loadDistrictCluster(){
            let cur = this
            AMapUI.load(['ui/geo/DistrictCluster', 'lib/$'], function(DistrictCluster) {
                //启动页面
                cur.initPage(DistrictCluster,$);
            });
        },
        initPage(DistrictCluster,$){
            let distCluster = new DistrictCluster({
                map: this.amap,
                zIndex:11,
                autoSetFitView:false,
                boundsQuerySupport:true,//范围查询
                getPosition: function(item) {
                    return item.position;
                }
            });
            distCluster.setData(this.pointData);
        },
        getRangePoints() {//数据获取
            let data1 = [];
            carLnglat().then(res=>{
                if(res.code === 200){
                    res.data.forEach(element => {
                        let lnglat = element.split(",");
                        data1.push({
                            position: [parseFloat(lnglat[0]),parseFloat(lnglat[1])]
                        })
                    })
                }
            })
            this.pointData = data1
        }
    },
    mounted(){
        this.getRangePoints();
        this.getAMap();
    }
}
</script>

<style scoped>
    #map_index{
        width: 100%;
        height: 100%;
    }
</style>

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vue使用高德地图聚合功能,首先需要安装并引入高德地图的JavaScript API。 1. 在`index.html`文件,添加如下代码引入高德地图的API: ```html <script src="https://webapi.amap.com/maps?v=1.4.15&key=your_api_key"></script> ``` 其,`your_api_key`是你在高德地图开放平台申请的API Key。 2. 在Vue组件,首先在`mounted`生命周期钩子初始化地图,并创建一个地图实例: ```javascript mounted() { // 初始化地图 AMap.initAMapApiLoader({ key: 'your_api_key', plugin: ['AMap.MarkerClusterer'] }); // 创建地图实例 this.map = new AMap.Map('mapContainer', { center: [lng, lat], // 地图经纬度 zoom: 13 // 地图缩放级别 }); } ``` 3. 在数据加载完成后,将需要聚合数据添加到地图上: ```javascript addMarkers() { this.points.forEach(point => { let marker = new AMap.Marker({ position: [point.lng, point.lat] // 标记位置经纬度 }); this.map.add(marker); }); } ``` 其,`this.points`是包含标记经纬度的数组。 4. 最后,启用聚合功能,将添加的标记进行聚合: ```javascript clusterMarkers() { let cluster = new AMap.MarkerClusterer(this.map, this.map.getAllOverlays(), { gridSize: 80, // 聚合的像素大小 renderCluserMarker(cluster) { let count = cluster.getMarkers().length; let div = document.createElement('div'); div.className = 'cluster-marker'; div.innerHTML = count; return new AMap.Icon({ size: new AMap.Size(40, 40), image: 'cluster.png', imageSize: new AMap.Size(40, 40), // 自定义聚合的样式和内容 div: div }); } }); } ``` 通过`AMap.MarkerClusterer`类创建一个聚合器对象,将地图实例、添加的标记聚合选项传入。 以上就是在Vue使用高德地图聚合功能的基本步骤。根据实际需求,可以进一步添加交互、自定义样式等功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

甜甜凉白开

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值