Openlayers 实现点位聚合

getMapData()
function getMapData(){
    RequestGet(SYSTEM_CONFIG.SERVER.LOCAL+'data/testData.json').then(res=>{
        if(res.success) {
            const plantMarkerList = res.data.items
            setTimeout(()=>{
                setCluster(plantMarkerList)
            },2000)
            mapRef.value.on('click',evt=>{
                // const coordinate = ol.proj.transform(evt.coordinate, 'EPSG:3857', 'EPSG:4326')
                let mouse = evt.coordinate // 鼠标点击的坐标位置
                const feature = mapRef.value.forEachFeatureAtPixel(evt.pixel, function(feature) {
                    return feature;
                });
                if (feature) {
                    console.log(feature, 'feature');
                    // 获取count属性
                    const count = feature.get('count');
                    // 聚合点--放大地图层级
                    if (count > 1) {
                        const czoom = mapRef.value.getView().getZoom();
                        mapRef.value.getView().animate({
                            center: evt.coordinate,
                            zoom: czoom + 1
                        });
                        // 具体点位
                    } else {
                        const custom = feature.get('features')[0].get('attribute');
                        if (custom) { // 如果是点击了坐标点
                            // 显示弹出窗口
                            popShow.value = true

                            const object={
                                '名称':custom.dwmc,
                                '年末职工人数':custom.zdmj,
                                '专业技术技能人员数':custom.zyjsjnrys,
                                '年末在院人数':custom.nmzyrs,
                                '机构管理人员数':custom.jgglrys,
                            }
                            dataDetail.value=object
                            detailXY.value=[Number(mouse[0].toFixed(2)),Number(mouse[1].toFixed(2))]
                        } else{
                            mapRef.value.getOverlays().clear()
                        }
                    }
                }
            });
        }
    })
}
// 聚合图层
function setCluster(list){
    // // 随机创建要素
    // var clusterSource = new ol.source.Vector();
    // debugger
    // for (var i = 1; i <= 10; i++) {
    //     var coordinates = [115.51949+ Math.random(), 35.33080 + Math.random()];
    //     console.log(coordinates)
    //     var feature = new ol.Feature(new ol.geom.Point(coordinates));
    //     clusterSource.addFeature(feature);
    // }
    // for (var i = 1; i <= 20; i++) {
    //     var coordinates = [115.53949 + Math.random(), 35.27080 + Math.random()];
    //     console.log(coordinates)
    //     var feature = new ol.Feature(new ol.geom.Point(coordinates));
    //     clusterSource.addFeature(feature);
    // }
    // console.log(clusterSource)
    const count = list.length;
    const features = new Array(count);
    for (let i = 0; i < count; i++) {
        const coordinate =new ol.format.WKT().readGeometry(list[i].xy).flatCoordinates;
        const attr = {
            lnglat: new ol.format.WKT().readGeometry(list[i].xy).flatCoordinates,
            town_name: list[i].gcwz,
        }

        features[i] = new ol.Feature({
            geometry: new ol.geom.Point(coordinate),
            attribute: attr,
        });
    }
    const clusterSource = new ol.source.Vector({
        features: features
    })
    // 聚合图层数
    // 据源
    const clusterSourceForLayer = new ol.source.Cluster({
        source: clusterSource,
        distance: 100
    })
// feature图片
    const base64Img = '';
    const clusterLayer = new ol.layer.Vector({
        id:'ccccc',
        source: clusterSourceForLayer,
        style: function (feature) {
            var size = feature.get('features').length;
            if (size == 1) {
                return new ol.style.Style({
                    image: new ol.style.Icon({
                        scale: 0.8,
                        src: base64Img,
                        anchor: [0.48, 0.52]
                    }),
                    text: new ol.style.Text({
                        font: 'normal 12px 黑体',
                        // // 对其方式
                        textAlign: 'center',
                        // 基准线
                        textBaseline: 'middle',
                        offsetY: -35,
                        offsetX: 0,
                        backgroundFill: new ol.style.Stroke({
                            color: 'rgba(0,0,255,0.7)',
                        }),
                        // 文本填充样式
                        fill: new ol.style.Fill({
                            color: 'rgba(236,218,20,1)'
                        }),
                        padding: [5, 5, 5, 5],
                        // text: `霸道的程序猿`,
                    })
                });
            } else {
                return new ol.style.Style({
                    // image: new ol.style.Circle({
                    //     radius: 30,
                    //     stroke: new ol.style.Stroke({
                    //         color: 'white'
                    //     }),
                    //     fill: new ol.style.Fill({
                    //         color: 'blue'
                    //     })
                    // }),
                    image: new ol.style.Icon({
                        scale: 0.8,
                        src: base64Img,
                        anchor: [0.48, 0.52]
                    }),
                    text: new ol.style.Text({
                        text: size.toString(),
                        fill: new ol.style.Fill({
                            color: 'red'
                        })
                    })
                });
            }
        }
    });
    console.log(clusterLayer)
    mapRef.value.addLayer(clusterLayer);
    console.log(mapRef.value)
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值