【问题标题】:Markerclusterer and infowindow v3 is not working properlyMarkerclusterer 和 infowindow v3 无法正常工作
【发布时间】:2013-03-14 01:03:51
【问题描述】:

我使用了来自 google 的示例代码作为 markerclusterer。我添加了一个代码来在markerclusterer v3的信息窗口中显示标记的坐标,但问题是它只将最后一个标记latlang加载到窗口中:任何人都可以帮助解决这个问题。

  function initialize() {
    var center = new google.maps.LatLng(37.4419, -122.1419);
    var map = new google.maps.Map(document.getElementById('map'), {
      zoom: 3,
      center: center,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    });

    google.maps.event.addListener(map, 'click', function() {
    infowindow.close();
    });

    var markers = [];
    for (var i = 0; i < 100; i++) {
      var dataPhoto = data.photos[i];
      var latLng = new google.maps.LatLng(dataPhoto.latitude,
          dataPhoto.longitude);
      var info = dataPhoto.photo_id;
      var marker = new google.maps.Marker({
        position: latLng


      });

    google.maps.event.addListener(marker, 'click', function() {

    infowindow.setPosition(latLng);
    infowindow.setContent(latLng.toString()); 

    infowindow.open(map,marker);


    });
      markers.push(marker);

    }



    var markerCluster = new MarkerClusterer(map, markers);
  }


  google.maps.event.addDomListener(window, 'load', initialize);

  var infowindow = new google.maps.InfoWindow(
  { 
  size: new google.maps.Size(150,50)
  });

</script>`

【问题讨论】:

标签: google-maps google-maps-api-3 infowindow markerclusterer


【解决方案1】:

在这里,我使用@geocodezip 提供的提示找到了答案。事件 addListener 应更改如下:

  google.maps.event.addListener(marker, 'click', (function(marker, i) {
    return function() {
      infowindow.setContent(marker.position.toString());
      infowindow.open(map, marker);
    }
  })(marker, i));

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2012-03-07
    • 1970-01-01
    • 2016-12-01
    • 2011-06-01
    • 2015-06-02
    • 2022-08-16
    • 2016-09-07
    • 1970-01-01
    相关资源
    最近更新 更多