0

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() を配置すると、マーカーオブジェクトが常に作成されていることがわかりますが、何らかの理由で、最初のマーカーがプロットされた後に他のマーカーがプロットされますマップにプロットされていません。

どんな助けや提案も歓迎します

ありがとう

4

2 に答える 2

0

setTimeout() の代わりに、setInterval() を試してください。

于 2011-09-08T11:48:55.130 に答える
0

このようなものでなければなりません

var map;
var lat = new Array() ;
lat=${latitude};
var lon= new Array();
lon=${longitude};
var oneByOneCounter=0;
var count=10;
var centerPoint;
function initMap(){  
   map = new Mapstraction('mymap','openlayers');    
   map.addControls({pan: true, zoom:'small', map_type:true});
  centerPoint= new LatLonPoint(lat[0],lon[0]);// or any point anyone wants to put center
   renderMarkerOneByOne();
   map.setCenterAndZoom(centerPoint,"desired zoom level");
 };

コードのデバッグに多くの時間を費やした後、解決策を見つけました。多くの maptraction 関数が openlayers API で正しく動作しない

于 2011-09-08T12:04:51.327 に答える