【问题标题】:Adding info windows to multiple circle overlays将信息窗口添加到多个圆形叠加层
【发布时间】:2013-05-08 10:23:10
【问题描述】:

我在为多个圆形叠加层中的每一个添加一个信息窗口时遇到问题。 当我单击一个圆圈时,会出现一个信息窗口,但不是在我单击的圆圈上,而是在最后一个添加的圆圈上。似乎每次执行循环时,都会将事件侦听器添加到每个圆圈中,但信息窗口的内容是从添加的最后一个圆圈派生的。

for (i in cityPoints) {
    var magnitudeOptions = {
        map: map,
        center: cityPoints[i].center,
        radius: cityPoints[i].magnitude,
        id:cityPoints[i].id,
        addr:cityPoints[i].addr,
        infoWindowIndex: i
     };
     cityCircle = new google.maps.Circle(magnitudeOptions);
     circlesArray.push(cityCircle);
     infoWindow = new google.maps.InfoWindow({ content: cityPoints[i].id + " " + cityPoints[i].addr });
     infoWindowsArray.push(infoWindow);
     google.maps.event.addListener(circlesArray[i], 'click', function (ev) {
         infoWindowsArray[i].setPosition(cityPoints[i].center);
         infoWindowsArray[i].open(map);
     });

}

【问题讨论】:

    标签: javascript google-maps-api-3


    【解决方案1】:

    那是因为您传递的 i 参数始终是最后一个。 试试这个

    <!DOCTYPE html>
    <html>
      <head>
        <meta name="viewport" content="initial-scale=1.0, user-scalable=no">
        <meta charset="utf-8">
        <title>Circles</title>
        <style>
        #map-canvas {
        height: 500px;
        width: 500px;
        </style>
        <script src="https://maps.googleapis.com/maps/api/js?v=3.exp&sensor=false"></script>
        <script>
    
    // Create an object containing LatLng, population.
    var cityPoints = {};
    cityPoints[0] = {
      center: new google.maps.LatLng(41.878113, -87.629798),
      id: 0,
      addr: 'avenue0',
      magnitude: 100000
    };
    cityPoints[1] = {
      center: new google.maps.LatLng(40.714352, -74.005973),
      id: 1, 
      addr: 'avenue1',
      magnitude: 100000
    };
    cityPoints[2] = {
      center: new google.maps.LatLng(34.052234, -118.243684),
      id: 2,
      addr: 'avenue2',
      magnitude: 100000
    }
    var cityCircle;
    var infoWindow = new google.maps.InfoWindow();  
    
    function initialize() {
      var mapOptions = {
        zoom: 4,
        center: new google.maps.LatLng(37.09024, -95.712891),
        mapTypeId: google.maps.MapTypeId.TERRAIN
      };
    
      var map = new google.maps.Map(document.getElementById('map-canvas'),
          mapOptions);
    
    for (i in cityPoints) {
               var magnitudeOptions = {
                    map: map,
                    center: cityPoints[i].center,
                    radius: cityPoints[i].magnitude,
                    id:cityPoints[i].id,
                    addr:cityPoints[i].addr,
                    infoWindowIndex: i
                };
       cityCircle = new google.maps.Circle(magnitudeOptions);
    
        google.maps.event.addListener(cityCircle, 'click', (function(cityCircle, i) {
            return function() {
                infoWindow.setContent(cityPoints[i].id + " " + cityPoints[i].addr);
                infoWindow.setPosition(cityCircle.getCenter());
                infoWindow.open(map);
            }
          })(cityCircle, i));
    }
    }
    google.maps.event.addDomListener(window, 'load', initialize);
    
        </script>
      </head>
      <body>
        <div id="map-canvas"></div>
      </body>
    </html>
    

    【讨论】:

    • 部分工作..当地图加载时,所有信息窗口都打开了,甚至没有点击。如果我关闭了一个信息窗口,我将无法通过单击圆圈再次打开它。
    • Re Alki!您使用 infoWindowsArray 而不向其推送任何内容。问题是我必须以某种方式引用我正在单击的圆圈,这是不可能的,因为每次循环执行时都会更新 cityCircle,尽管圆圈仍保留在地图上。如果我错了,请纠正我
    • 还是不行。我尝试了不同的方法,仍然没有。一切都归结为获得对被点击的圆圈的引用
    • tq..对我真的有用!! =)
    • @alkis 更新后的代码只允许打开 1 个信息窗口。如果我点击其他圈子,前一个信息窗口会自动关闭。您能建议我如何更改代码,以便仅在我点击关闭后关闭按钮。因为有些时候我想看到几个信息窗口。谢谢,
    【解决方案2】:

    这称为closure,谷歌有关于如何使用标记的信息。以下是如何使用圆圈进行操作。 在代码中,“位置”是一个数组,其中包含我想要绘制为圆圈的所有纬度和经度。

    for (i = 0; i < locations.length; i++) {  
      currentLocation = locations[i].latlng;
      var currentLatLng = new google.maps.LatLng(parseFloat(currentLocation[0]),parseFloat(currentLocation[1]) )
    
      var newCircle = new google.maps.Circle({
        center: currentLatLng,
        radius:10000,
        strokeColor:"#0000FF",
        strokeOpacity:0.8,
        strokeWeight:2,
        fillColor:"#0000FF",
        fillOpacity:0.4,
        map:map,
        clickable:true,
      });
    
      attachSecretMessage(locations[i].instname+', Tuition: $'+locations[i].tuitionfee02_tf) 
    
    }
    
    
    function attachSecretMessage(tuitionInfo){
    
      var infowindow = new google.maps.InfoWindow({
        content: tuitionInfo,
        position: currentLatLng
      });
    
      myCity.addListener('click', function() {
         infowindow.open(map);
      });
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-03-06
      • 2015-12-17
      • 1970-01-01
      • 1970-01-01
      • 2018-06-05
      • 1970-01-01
      相关资源
      最近更新 更多