maptraction を介して使用される openlayers マップに 10 個のマーカーを表示するページがあります。
最初にマップをロードしてから、毎秒マーカーを1つずつロードしたいのですが、 window.setTimeout() を使用してみました。マップをロードし、その後最初のマーカーのみをロードしてから停止します。
var map;
var lat = new Array() ;
lat=${latitude};
var lon= new Array();
lon=${longitude};
var oneByOneCounter=0;
var count=10;
function initMap(){
map = new Mapstraction('mymap','openlayers');
map.setCenter(new LatLonPoint(0.0,0.0));
map.addControls({pan: true, zoom:'small', map_type:true});
renderMarkerOneByOne();
map.autoCenterAndZoom();
};
function renderMarkerOneByOne() {
if (oneByOneCounter < count) {
latitude= lat[oneByOneCounter];
longitude= lon[oneByOneCounter];
var point = new LatLonPoint(latitude,longitude);
var marker = new Marker(point);
var info = "("+(oneByOneCounter+1)+")";
marker.setInfoBubble(info);
marker.setHover(true);
marker.setIcon('icon_green.png', [27,31]);
map.addMarker(marker);
oneByOneCounter++;
window.setTimeout("renderMarkerOneByOne()", 1000);
} else {
oneByOneCounter = 0;
}
}
renderMarkerOneByOne() 関数が正しく実行され、alert() を配置すると、マーカーオブジェクトが常に作成されていることがわかりますが、何らかの理由で、最初のマーカーがプロットされた後に他のマーカーがプロットされますマップにプロットされていません。
どんな助けや提案も歓迎します
ありがとう