使用百度地图BMap.InfoWindow,分别显示不同的信息窗口

使用BMap.InfoWindow,在for循环展示信息的时候,总是显示最后一条信息的数据。

其实,可以讲BMap.InfoWindow的创建写在一个单独的function中。这样,每一个BMap.InfoWindow,就是显示的当条的信息。

 


function callback(xyResults) {
   var xyResult = null;
   for(var i = 0;i<xyResults.length;i++){
    xyResult = xyResults[i];
    xySource = qntPoints.points[count*maxCon+i];
    if (xyResult.error != 0) {
     continue;
    }
    var point = new BMap.Point(xyResult.x, xyResult.y);
    var myIcon1 = new BMap.Icon("<%=request.getContextPath()%>/js/map/car30.png", new BMap.Size(30,30));
    var marker = new BMap.Marker(point,{icon:myIcon1}); 
    map.addOverlay(marker);
    txt = "<p style='font-size:14px;'>"+xySource.desc+"</p>" ;
    addInfo(txt,marker);
    if(xyResults.length-1==i){
     map.centerAndZoom(point,6);
    }
   }
   if(qntPoints.parArray.length>++count){
    BMap.Convertor.transMore(qntPoints.parArray[count], 0, callback);
   }else{
    count = 0;
    qntPoints.parArray = new Array();
   }
  }
  
  function addInfo(txt,marker){
    infoWindow = new BMap.InfoWindow(txt);
    marker.addEventListener("click", function(){this.openInfoWindow(infoWindow);});
  }



 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值