腾讯地图 聚合点下的Marker点击事件

自己开发项目遇到的小问题:

1、聚合点下如何添加Marker点的点击事件

2、腾讯地图的实例是H5的自己实力不济转成vue的时候会出现报错,大家可以一起探讨

关键点:

1、在创建点标记图层后才可以设置点击事件

marker = new TMap.MultiMarker

//监听marker点击事件

marker.on("click", eventClick)

//创建点击事件

var eventClick = function (evt) { console.log(evt.geometry.id) }

接下来是代码(H5)复制粘贴就能用

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>自定义点聚合功能</title>
    <style>
        html,
        body {
            margin: 0;
            padding: 0;
            overflow: hidden;
            height: 100%;
        }

        #mapContainer {
            position: relative;
            height: 100%;
            width: 100%;
        }

        .clusterBubble {
            border-radius: 50%;
            color: #fff;
            font-weight: 500;
            text-align: center;
            opacity: 0.88;
            background-image: linear-gradient(139deg, #ff3d66 0%, #ff3574 100%);
            box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.20);
            position: absolute;
            top: 0px;
            left: 0px;
        }

        .locicon {
            position: absolute;
            bottom: 20px;
            right: 15px;
            width: 50px;
            height: 50px;
            z-index: 10000;
        }
    </style>
</head>
<script charset="utf-8" src="https://map.qq.com/api/gljs?v=1.exp&key=OB4BZ-D4W3U-B7VVO-4PJWW-6TKDJ-WPB77"></script>

<body onload="init()">
    <div id='mapContainer'></div>
    <img class="locicon" onclick="setCenter()" src="./icon_location_s.png" alt="">
    <script>
        var map;
        var center = new TMap.LatLng(39.953416, 116.380945);
        var ClusterBubbleClick;
        function init() {
            var drawContainer = document.getElementById('mapContainer');
            map = new TMap.Map('mapContainer', {
                zoom: 16.5,
                minZoom: 10,             //此处设置地图的缩放级别  最小值
                maxZoom: 17,           //此处设置地图的缩放级别  最大值
                pitch: 0,
                center: center,
                mapStyleId: 'style 1'
            });

            // 创建点聚合
            var markerCluster = new TMap.MarkerCluster({
                id: 'cluster',
                map: map,
                enableDefaultStyle: false, // 关闭默认样式
                minimumClusterSize: 3,
                geometries: [{ // 点数组
                    position: new TMap.LatLng(39.953416, 116.480945)
                },
                {
                    position: new TMap.LatLng(39.984104, 116.407503)
                },
                {
                    position: new TMap.LatLng(39.908802, 116.497502)
                },
                {
                    position: new TMap.LatLng(40.040417, 116.373514)
                },
                {
                    position: new TMap.LatLng(39.953416, 116.380945)
                },
                {
                    position: new TMap.LatLng(39.984104, 116.307503)
                },
                {
                    position: new TMap.LatLng(39.908802, 116.397502)
                },
                {
                    position: new TMap.LatLng(40.040417, 116.273514)
                },
                ],
                zoomOnClick: true,
                gridSize: 60,
                averageCenter: false
            });
            var clusterBubbleList = [];
            var markerGeometries = [];
            var marker = null;// 监听聚合簇变化
            markerCluster.on('cluster_changed', function (e) {
                // 销毁旧聚合簇生成的覆盖物
                if (clusterBubbleList.length) {
                    clusterBubbleList.forEach(function (item) {
                        item.destroy();
                    })
                    clusterBubbleList = [];
                }
                markerGeometries = [];

                // 根据新的聚合簇数组生成新的覆盖物和点标记图层
                var clusters = markerCluster.getClusters();
                clusters.forEach(function (item) {
                    if (item.geometries.length > 1) {
                        let clusterBubble = new ClusterBubble({
                            map,
                            position: item.center,
                            content: item.geometries.length,
                        });
                        clusterBubble.on('click', () => {
                            map.fitBounds(item.bounds);
                        });
                        clusterBubbleList.push(clusterBubble);
                    } else {
                        markerGeometries.push({
                            position: item.center
                        });
                    }
                });
                if (marker) {
                    // 已创建过点标记图层,直接更新数据
                    marker.setGeometries(markerGeometries);
                } else {
                    // 创建点标记图层
                    marker = new TMap.MultiMarker({
                        map,
                        styles: {
                            default: new TMap.MarkerStyle({
                                'width': 50,
                                'height': 50,
                                'anchor': {
                                    x: 17,
                                    y: 21,
                                },
                                'src': '',
                            }),
                        },
                        geometries: markerGeometries
                    });
                    //监听marker点击事件
                    marker.on("click", eventClick)
                }
            });
            var eventClick = function (evt) {
                console.log(evt.geometry.id)
            }
            //添加坐标
            markerCluster.updateGeometries(
                [
                    {
                        "styleId": "marker",
                        "id": "4",
                        "position": new TMap.LatLng(39.994104, 116.287503),
                    }
                ]
            )
            var circle = new TMap.MultiCircle({
                map,
                styles: {
                    // 设置圆形样式
                    circle: new TMap.CircleStyle({
                        color: 'rgba(255, 61, 102, 0.08)',
                        showBorder: true,
                        borderColor: 'rgba(255,255,255,1)',
                        borderWidth: 1
                    })
                },
                geometries: [
                    {
                        styleId: 'circle',
                        center: center,
                        radius: 200
                    }
                ]
            })
        }
        // 以下代码为基于DOMOverlay实现聚合点气泡
        //设置地图中心点事件
        function setCenter() {
            map.easeTo({ zoom: 16.5, rotation: 0, center: center }, { duration: 1000 });//平滑缩放,旋转到指定级别
        }
        function ClusterBubble(options) {
            TMap.DOMOverlay.call(this, options);
        }

        ClusterBubble.prototype = new TMap.DOMOverlay();

        ClusterBubble.prototype.onInit = function (options) {
            this.content = options.content;
            this.position = options.position;
        };

        // 销毁时需要删除监听器
        ClusterBubble.prototype.onDestroy = function () {
            this.dom.removeEventListener('click', this.onClick);
            this.removeAllListeners();
        };

        ClusterBubble.prototype.onClick = function () {
            this.emit('click');
        };

        // 创建气泡DOM元素
        ClusterBubble.prototype.createDOM = function () {
            var dom = document.createElement('div');
            dom.classList.add('clusterBubble');
            dom.innerText = this.content;
            dom.style.cssText = [
                'width: ' + (40 + parseInt(this.content) * 2) + 'px;',
                'height: ' + (40 + parseInt(this.content) * 2) + 'px;',
                'line-height: ' + (40 + parseInt(this.content) * 2) + 'px;',
            ].join(' ');

            // 监听点击事件,实现zoomOnClick
            this.onClick = this.onClick.bind(this);
            dom.addEventListener('click', this.onClick);
            return dom;
        };

        ClusterBubble.prototype.updateDOM = function () {
            if (!this.map) {
                return;
            }
            // 经纬度坐标转容器像素坐标
            let pixel = this.map.projectToContainer(this.position);

            // 使文本框中心点对齐经纬度坐标点
            let left = pixel.getX() - this.dom.clientWidth / 2 + 'px';
            let top = pixel.getY() - this.dom.clientHeight / 2 + 'px';
            this.dom.style.transform = `translate(${left}, ${top})`;

            this.emit('dom_updated');
        };

        window.ClusterBubble = ClusterBubble;
    </script>
</body>

</html>

 

posted @ 2021-03-31 16:52  会飞的小白  阅读(3420)  评论(2编辑  收藏  举报