android maps:数组索引越界异常

时间:2010-12-07 06:56:40

标签: android google-maps android-maps

我的任务是显示Android地图中显示的458个标记。为避免与性能相关的问题,我使用AsyncTask实例更新了地图上的数据。

以下是我所做的简短情景。

  1. 我取得了英国各地458个地点的纬度/经度。
  2. 我运行循环,根据Android博客教程,我将它们添加到ItemizedOverlay
  3. 每50次迭代后,我调用publishProgress方法在地图中放置50个标记。
  4. 在第50次迭代之后,流程通过onProgressUpdate进入publishProgress,这是我的onProgressUpdate方法代码

    // MapOverLays = mapView.getOverlays(); 
    //This line was called in asyc task's constructor   
    // Hello Overlay is an instance of ItemizedOverlay.
    mapOverlays.add(helloOverLay);
    //MapView.getController - Also called in Constructor
    controller.setZoom(12);
    
    controller.animateTo(centerPoint);
    controller.setCenter(centerPoint);
    

    此代码抛出ArrayIndexOutOfBoundException,并且logcat不显示我的模块中的任何类。如果它解释了我的问题,这是logcat转储。

    12-07 11:34:48.644: ERROR/AndroidRuntime(508): java.lang.ArrayIndexOutOfBoundsException
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at com.google.android.maps.ItemizedOverlay.getIndexToDraw(ItemizedOverlay.java:211)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at com.google.android.maps.ItemizedOverlay.draw(ItemizedOverlay.java:240)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at com.google.android.maps.Overlay.draw(Overlay.java:179)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at com.google.android.maps.OverlayBundle.draw(OverlayBundle.java:42)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at com.google.android.maps.MapView.onDraw(MapView.java:476)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.View.draw(View.java:6535)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.ViewGroup.drawChild(ViewGroup.java:1531)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1258)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.ViewGroup.drawChild(ViewGroup.java:1529)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1258)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.View.draw(View.java:6538)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.widget.FrameLayout.draw(FrameLayout.java:352)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.ViewGroup.drawChild(ViewGroup.java:1531)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1258)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.ViewGroup.drawChild(ViewGroup.java:1529)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1258)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.View.draw(View.java:6538)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.widget.FrameLayout.draw(FrameLayout.java:352)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1830)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.ViewRoot.draw(ViewRoot.java:1349)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.ViewRoot.performTraversals(ViewRoot.java:1114)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.view.ViewRoot.handleMessage(ViewRoot.java:1633)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.os.Handler.dispatchMessage(Handler.java:99)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.os.Looper.loop(Looper.java:123)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at android.app.ActivityThread.main(ActivityThread.java:4363)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at java.lang.reflect.Method.invokeNative(Native Method)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at java.lang.reflect.Method.invoke(Method.java:521)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
    12-07 11:34:48.644: ERROR/AndroidRuntime(508):     at dalvik.system.NativeStart.main(Native Method)
    

    P.S。我已经使用相对较小(10)和相对较大(150)的迭代而不是50来测试应用程序。但应用程序会抛出相同的错误。

5 个答案:

答案 0 :(得分:3)

我遇到了同样的问题。看起来这是因为更新了ItemizedOverlay中的数据而后来没有调用populate


public class ListOverlay extends ItemizedOverlay<OverlayItem> {
...
  public synchronized void updateLocations(List<OverlayItem> newLocations) {
    locations.clear();
    locations.addAll(newLocations);
    populate(); // this was missing
  }
  protected synchronized OverlayItem createItem(int index) {
    return locations.get(index);
  }
  public synchronized int size() {
    return locations.size();
  }
}

答案 1 :(得分:1)

setLastFocusedIndex(-1); 填充();

不是“永远”工作!!!

答案 2 :(得分:0)

我暂时得到了解决方案。我不是经常添加引脚而是首先准备整个数据,然后使用onPostExecute()将其添加到地图中,如Android 2.1 GoogleMaps ItemizedOverlay ConcurrentModificationException所述,但它仍然不符合我的要求,以节省加载所有引脚的时间。但是我可以摆脱那个例外。但是等待任何改善加载时间的建议......无论如何,谢谢......: - )

答案 3 :(得分:0)

我遇到了同样的问题,只是我得到了一个稍微不同的堆栈跟踪。我发现解决方案是在添加叠加层后对itemizedOverlay对象执行以下操作:

setLastFocusedIndex(-1);
populate();

我不能相信这一点,我找到了答案here。我不知道你为什么要这样做,但这对我有用。

答案 4 :(得分:0)

每次将新的图钉项添加到叠加层后,只需在UI线程中调用mapView的invalidate()。