繁体   English   中英

更新MarkerClusterer

[英]Updating MarkerClusterer

我已经根据当前地图中包含的位置(来自数据库)来更新了地图。 但是,我有一些问题以同样的方式更新clusturers。 我尝试在gmarkers [i] .setMap(null);之后添加markerClusterer.clearMarkers(); 但它不起作用(即使标记也不再更新)。

这是代码:

var map;  
var gmarkers = [];

function initialize() {
    var latlng = new google.maps.LatLng(46.7, 2.5);   
    var myOptions = {
        zoom: 6, 
        center: latlng,
        mapTypeId: google.maps.MapTypeId.ROADMAP
    };   

    map = new google.maps.Map(document.getElementById('map'), myOptions);

    /* Ici, on ajoute l'écouteur d'événement suite à un glisser / déposer  */ 
    google.maps.event.addListener(map, 'idle', function() {
        var bds = map.getBounds();
        var South_Lat = bds.getSouthWest().lat();
        var South_Lng = bds.getSouthWest().lng();
        var North_Lat = bds.getNorthEast().lat();
        var North_Lng = bds.getNorthEast().lng();
        var Zoom_Level = map.getZoom();         // hide and delete the existing markers

        for (var i=0; i<gmarkers.length; i++) {
            gmarkers[i].setMap(null);
        }

        gmarkers = [];
        downloadUrl("./includes/AjaxMarkers.php?maxlat="+North_Lat+"&minlat="+South_Lat+"&minlong="+South_Lng+"&maxlong="+North_Lng+"&zoom="+Zoom_Level, function(data) { 
            var xml = xmlParse(data);
            var markers = xml.documentElement.getElementsByTagName("marker");
            for (var i = 0; i < markers.length; i++) {
                createMarker(parseFloat(markers[i].getAttribute("lat")), parseFloat(markers[i].getAttribute("lng")), markers[i].getAttribute('titre'));
            }

            var markerClusterer = new MarkerClusterer(map, gmarkers);
        });

        markerClusterer.resetViewport()
    });
}

function createMarker(lat, lng, titre) {
    var latlng = new google.maps.LatLng(lat, lng);
    var marker = new google.maps.Marker({
        position: latlng,
        map: map,
        title: titre    });    // keep a reference to created markers so you can remove them
    gmarkers.push(marker);
}

谢谢!

您的markerClusterer是在downloadUrl的回调中定义的,在该范围之外无法访问。

最简单的解决方法是在全局上下文中定义它。

var map;  
var gmarkers = [];
var markerClusterer = null;

function initialize() {

然后在downloadUrl回调中:

    downloadUrl("./includes/AjaxMarkers.php?maxlat="+North_Lat+"&minlat="+South_Lat+"&minlong="+South_Lng+"&maxlong="+North_Lng+"&zoom="+Zoom_Level, function(data) { 
        var xml = xmlParse(data);
        var markers = xml.documentElement.getElementsByTagName("marker");
        for (var i = 0; i < markers.length; i++) {
            createMarker(parseFloat(markers[i].getAttribute("lat")), parseFloat(markers[i].getAttribute("lng")), markers[i].getAttribute('titre'));
        }

        markerClusterer = new MarkerClusterer(map, gmarkers);
    });

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM