【发布时间】:2012-07-16 17:49:23
【问题描述】:
我不想编写动态壁纸,我需要一个当前按下的点列表。我将点存储在 SpareArray 中(与 HashMap 基本相同,但速度更快)。
现在,当我用两根手指(1 和 2)触摸屏幕并抬起手指(第一根手指 2,而不是 1)时,它可以工作。但是当我先抬起手指 1 时,应用程序崩溃了。我必须以相反的顺序抬起手指然后按下它们。
@Override
public void onTouchEvent(MotionEvent event) {
for (int i = 0; i < event.getPointerCount(); i++) {
switch (event.getAction() & MotionEvent.ACTION_MASK) {
case MotionEvent.ACTION_DOWN:
case MotionEvent.ACTION_POINTER_DOWN:
case MotionEvent.ACTION_MOVE:
int pID = event.getPointerId(i);
Points.put(pID, new Point((int)event.getX(pID), (int)event.getY(pID))); //CRASH HERE
break;
case MotionEvent.ACTION_UP:
case MotionEvent.ACTION_POINTER_UP:
Points.remove(event.getPointerId(i));
break;
}
}
super.onTouchEvent(event);
handler.post(drawRunnable);
}
我总是收到“java.lang.IllegalArgumentException:pointerIndex out of range”异常
谢谢,多米尼克
编辑:堆栈跟踪
07-16 19:55:58.354: E/AndroidRuntime(4986): FATAL EXCEPTION: main
07-16 19:55:58.354: E/AndroidRuntime(4986): java.lang.IllegalArgumentException: pointerIndex out of range
07-16 19:55:58.354: E/AndroidRuntime(4986): at android.view.MotionEvent.nativeGetAxisValue(Native Method)
07-16 19:55:58.354: E/AndroidRuntime(4986): at android.view.MotionEvent.getX(MotionEvent.java:1974)
07-16 19:55:58.354: E/AndroidRuntime(4986): at net.ta.livewp.LiveWallpaper$xEngine.onTouchEvent(LiveWallpaper.java:103)
07-16 19:55:58.354: E/AndroidRuntime(4986): at android.service.wallpaper.WallpaperService$IWallpaperEngineWrapper.executeMessage(WallpaperService.java:1047)
07-16 19:55:58.354: E/AndroidRuntime(4986): at com.android.internal.os.HandlerCaller$MyHandler.handleMessage(HandlerCaller.java:61)
07-16 19:55:58.354: E/AndroidRuntime(4986): at android.os.Handler.dispatchMessage(Handler.java:99)
07-16 19:55:58.354: E/AndroidRuntime(4986): at android.os.Looper.loop(Looper.java:137)
07-16 19:55:58.354: E/AndroidRuntime(4986): at android.app.ActivityThread.main(ActivityThread.java:4575)
07-16 19:55:58.354: E/AndroidRuntime(4986): at java.lang.reflect.Method.invokeNative(Native Method)
07-16 19:55:58.354: E/AndroidRuntime(4986): at java.lang.reflect.Method.invoke(Method.java:511)
07-16 19:55:58.354: E/AndroidRuntime(4986): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
07-16 19:55:58.354: E/AndroidRuntime(4986): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
07-16 19:55:58.354: E/AndroidRuntime(4986): at dalvik.system.NativeStart.main(Native Method)
【问题讨论】:
-
以后,如果您要发送任何类型的
Exception,您应该发布您的日志,而不仅仅是Exception的名称。您的日志将指向它被抛出的特定代码行,这最终对您和任何试图帮助您的人都很有用。 -
对不起,我编辑了我的帖子,但该行被标记(向右滚动)
标签: java android multi-touch