投放本站广告请联系:
extjscn#126.com
Sencha map infowindow 的问题
在使用map的过程中,发现多个地标的infowindow是无法关闭的
因为在sencha中不如在js中可以设定多个全局变量来控制,所以google搜来的教程大多不可用
写下我的解决方案
showinfomessage:function (map, markers, index) { google.maps.event.addListener(markers, 'click', function (event) { if (markers) { for (i in markers) { if(markers[i].infowindow) markers[i].infowindow.close(); } } markers
.infowindow.open(map, markers
); }); }, onMapMaprender:function (mapview, gmap, options) { var markers = []; var i =0; store.load(function (records, operation, success) { store.each(function (record) { i=i+1; markers[i]= new google.maps.Marker({ position:new google.maps.LatLng([record.get('latitude')], [record.get('longitude')]), map:gmap, draggable:true, title:record.get('name'), animation:google.maps.Animation.DROP }); markers[i].infowindow = new google.maps.InfoWindow({ content: contentString }); mapview.showinfomessage(gmap, markers,i); }) }); }
讲数组作为参数传递
有人会问为什么不在一个函数里写完,发现
google.maps.event.addListener
如果不在另外一个函数里会只增加到一个marker上
作者:yiboo
原文:http://www.csdn123.com/html/blogs/20130417/3260.htm
- 关键字:
- 要发表评论,请先登录