Google Maps API:使用MarkerClusterer +切换

时间:2015-04-24 14:16:40

标签: javascript google-maps toggle geojson markerclusterer

我的GeoJson图层有问题,我想要聚类(使用MarkerClusterer),然后能够通过复选框或类似方式显示和隐藏它们。因此,我尝试了类似下面的代码:

function initialize() {
    var mapOptions = {
        center: new google.maps.LatLng(52.515696, 13.392624),
        zoom: 11,
        mapTypeId: google.maps.MapTypeId.ROADMAP
    };

    var map = new google.maps.Map(document.getElementById("map"),
            mapOptions);
    var bounds = new google.maps.LatLngBounds();
    var barLayer = new google.maps.Data();
    var cafeLayer = new google.maps.Data();

    barLayer.loadGeoJson('json/eat_drink/bar.geojson');
    cafeLayer.loadGeoJson('json/eat_drink/cafe.geojson');


    var markerClusterer = new MarkerClusterer(map); 
    var infowindow = new google.maps.InfoWindow();  
    markerClusterer.setMap(map);

    function displayMarkers(layer) { 
    var layer = layer;
    google.maps.event.addListener(layer, 'addfeature', function (e) {
        if (e.feature.getGeometry().getType() === 'Point') {
            var marker = new google.maps.Marker({
                position: e.feature.getGeometry().get(),
                title: e.feature.getProperty('name'),
                map: map
            });
            // open the infoWindow when the marker is clicked
            google.maps.event.addListener(marker, 'click', function (marker, e) {
                return function () {
                    var myHTML = e.feature.getProperty('name');
                    infowindow.setContent("<div style='width:150px; text-align: center;'>"+myHTML+"</div>");
                    infowindow.setPosition(e.feature.getGeometry().get());
                    infowindow.setOptions({pixelOffset: new google.maps.Size(0,-30)});
                    infowindow.open(map, marker);
                };
            }(marker, e));
            markerClusterer.addMarker(marker);
            bounds.extend(e.feature.getGeometry().get());
            map.fitBounds(bounds);
            map.setCenter(e.feature.getGeometry().get());
        }
    });
    layer.setMap(null);
    google.maps.event.addListener(map, "click", function () {
        infowindow.close();
    });

};

document.getElementById('bar').onclick = function(){            // enable and disable markers
        if(document.getElementById('bar').checked == true){
                displayMarkers(barLayer);
        }else{
            return null; 
        }
        };
}

不幸的是,这不起作用,我不是没有确切原因。 如果我删除代码周围的displayMarkers()函数并将“layer”替换为所需的GeoJson图层,例如“barLayer”,它运作得很好。 由于我最终会得到大量的GeoJason图层,所以我更喜欢像这样的“紧凑”解决方案,多次复制代码。你有没有想法如何正确地做到这一点?

1 个答案:

答案 0 :(得分:0)

我担心我做的不仅仅是重构你的代码。你可以尝试一下,如果它不起作用,请指出哪些不起作用?

function displayMarkers(layer, map, markerClusterer) {
    google.maps.event.addListener(layer, 'addfeature', function(e) {
        if (e.feature.getGeometry().getType() === 'Point') {
            var marker = new google.maps.Marker({
                position: e.feature.getGeometry().get(),
                title: e.feature.getProperty('name'),
                map: map
            });
            // open the infoBox when the marker is clicked
            google.maps.event.addListener(marker, 'click', function(e) {
                var myHTML = e.feature.getProperty('name');
                var infowindow = new google.maps.InfoWindow();
                infowindow.setContent("<div style='width:150px; text-align: center;'>" + myHTML + "</div>");
                infowindow.setPosition(e.feature.getGeometry().get());
                infowindow.setOptions({
                    pixelOffset: new google.maps.Size(0, -30)
                });
                infowindow.open(map, marker);
                google.maps.event.addListener(map, "click", function() {
                    infowindow.close();
                });
            });
            markerClusterer.addMarker(marker);
            var bounds = new google.maps.LatLngBounds();
            bounds.extend(e.feature.getGeometry().get());
            map.fitBounds(bounds);
            map.setCenter(e.feature.getGeometry().get());
        }
    });
    layer.setMap(null);
}

function initialize() {
    var mapOptions = {
        center: new google.maps.LatLng(52.515696, 13.392624),
        zoom: 11,
        mapTypeId: google.maps.MapTypeId.ROADMAP
    };
    var map = new google.maps.Map(document.getElementById("map"), mapOptions);
    var barLayer = new google.maps.Data();
    var cafeLayer = new google.maps.Data();
    barLayer.loadGeoJson('json/eat_drink/bar.geojson');
    cafeLayer.loadGeoJson('json/eat_drink/cafe.geojson');
    var markerClusterer = new MarkerClusterer(map);
    markerClusterer.setMap(map);
    document.getElementById('bar').onclick = function() { // enable and disable streetViewControl
        if (document.getElementById('bar').checked == true) {
            displayMarkers(barlayer, map, markerClusterer);
        } else {
            return null;
        }
    };
}