在 Vuejs 中使用谷歌地图标记集群

Posted

技术标签:

【中文标题】在 Vuejs 中使用谷歌地图标记集群【英文标题】:Using Google map marker cluster in Vuejs 【发布时间】:2019-04-29 14:20:09 【问题描述】:

我正在 Vuejs 上构建一个小型应用程序,我正在使用 npm package 替代 js-marker-clusterer 在我从 API 获得响应后尝试加载地图,以下是我的代码:

var MarkerClusterer = require('node-js-marker-clusterer');
let rawMarkers=[];
let rawMarkers2=[];
$.each(response.data.data, function( key, value) 
    if((value.latitude != null) && (value.longitude != null) )
    
        rawMarkers.push(
            name:value.name,
            lat:parseFloat(value.latitude),
            long:parseFloat(value.longitude),
            // conAr:value.technical_description.construction_area,
        );
    
);
// console.log( rawMarkers);
// console.log( rawMarkers.map(obj => Object.values(obj)));

rawMarkers2=rawMarkers.map(obj => Object.values(obj));
let markers =rawMarkers2;

let displayDetails=[];
$.each(response.data.data, function( key, value) 
    let det='<div class="info_content">' +
        // '<h3>'+value.name+'</h3>' +
        '<a href="/#/projectprofile/'+value.slug+'" target="_blank">'+value.name+'</a>'+
        '</div>';
    displayDetails.push(
        det:det,
    );
    det='';
);
// console.log( displayDetails.map(obj => Object.values(obj)));
let infoWindowContent =displayDetails.map(obj => Object.values(obj));

if (this.mapState.initMap)  // map is already ready
    /*console.log("from mounted :"+this.mapState.initMap);
    alert("from mounted :"+this.mapState.initMap);*/


    let bounds = new google.maps.LatLngBounds();

    let map = new google.maps.Map(document.getElementById('map'), 
        zoom: 4,
        center: lat: 21.7679, lng: 78.8718,
        mapTypeId: google.maps.MapTypeId.ROADMAP
    );
    let labels = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';


    let markerBg = 
        url: 'http://maps.google.com/mapfiles/ms/icons/red-dot.png',
        // This marker is 20 pixels wide by 32 pixels high.
        size: new google.maps.Size(80, 30),
        // The origin for this image is (0, 0).
        origin: new google.maps.Point(0, 0),
        // The anchor for this image is the base of the flagpole at (0, 32).
        anchor: new google.maps.Point(0, 32)
    ;

    // Info Window Content
    // console.log(infoWindowContent);

    // Display multiple markers on a map
    let infoWindow = new google.maps.InfoWindow(), marker, i;

    // Loop through our array of markers & place each one on the map
    for( i = 0; i < markers.length; i++ ) 
        let position = new google.maps.LatLng(markers[i][1], markers[i][2]);
        bounds.extend(position);
        marker = new google.maps.Marker(
            position: position,
            map: map,
            label: markers[i][3],
            title: markers[i][0],
            animation: google.maps.Animation.DROP,
            icon: markerBg,
        );

        //Marker Cluster operation
        var mcOptions = 
            //imagePath: 'https://googlemaps.github.io/js-marker-clusterer/images/m',
            styles:[

                url: "https://googlemaps.github.io/js-marker-clusterer/images/m1.png",
                width: 53,
                height:53,
                fontFamily:"comic sans ms",
                textSize:15,
                textColor:"red",
                //color: #00FF00,
            ]

        ;
        var mc = new MarkerClusterer(map, marker, mcOptions);

        // Allow each marker to have an info window
        google.maps.event.addListener(marker, 'click', (function (marker, i) 
            return function () 
                infoWindow.setContent(infoWindowContent[i][0]);
                infoWindow.open(map, marker);
            
        )(marker, i));

        // Automatically center the map fitting all markers on the screen
        map.fitBounds(bounds);
    

但这显示地图是这样的:

我希望图像应该是这样的:

我从这个JSFiddle得到代码参考

帮助我实现这一目标。谢谢

【问题讨论】:

【参考方案1】:

您正在为所有标记创建一个MarkerCluster,而是将所有标记存储在数组中,然后只创建一个MarkerCluster,如问题所附链接所示。

var gMarkers = [];
for( i = 0; i < markers.length; i++ ) 

    // add markers on the map
    ....

    // attach event handlers
    ....

    gMarkers.push(marker);

var mc = new MarkerClusterer(map, gMarkers , mcOptions);

【讨论】:

这行得通,在您的回答中,我们需要有一个不同的variable 名称,因为它不会输入for loop 没有意识到现有的标记数组,修复它!

以上是关于在 Vuejs 中使用谷歌地图标记集群的主要内容,如果未能解决你的问题,请参考以下文章

从谷歌地图中删除标记集群[不仅仅是标记]

无法单击标记 - 谷歌地图集群Android,无法在谷歌地图中显示信息窗口

如何在集群中的谷歌地图标记上创建点击事件?

在 android 谷歌地图中更改集群管理器项目图标

如何在谷歌地图的集群中为标记设置我自己的图标

如何在谷歌地图中显示集群时隐藏标记