Android MotionEvent.getHistoricalX为什么会出现异常

时间:2013-07-31 14:09:03

标签: android exception motionevent

我正在使用GestureDetector.OnGestureListener来实现Android中的缩放功能。我正在扩展TextView类,因此方法setTextSize()已经实现。以下是我onScroll()的代码。

 @Override
 public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
     if(LOGGING) Log.v(MODULE_NAME, "onScroll()");

     float x, y;
     float oldDist, newDist;

     if (e2.getPointerCount() == 2 && 
         ((e2.getAction() & MotionEvent.ACTION_MASK) == MotionEvent.ACTION_MOVE)) {
         x = e2.getHistoricalX(0, 0) - e2.getHistoricalX(1, 0);
         y = e2.getHistoricalY(0, 0) - e2.getHistoricalY(1, 0);
         oldDist = FloatMath.sqrt(x * x + y * y);
         if (oldDist > 10) {
             if (LOGGING) Log.d(MODULE_NAME, "Starting ZOOM mode");                    
             x = e2.getX(0) - e2.getX(1);
             y = e2.getY(0) - e2.getY(1);
             newDist = FloatMath.sqrt(x * x + y * y);

             if (newDist > 30) {
                    float scaleFactor = (newDist > oldDist) ? oldDist : newDist;
                    float scale = (newDist - oldDist) / scaleFactor;
                    // Callback to be processed in main thread
                    setTextSize(scale * currentTextSize);
                    oldDist = newDist;
             }      
             scrollDetected = true;
             return true;
         }
     }
     return false;            
 }

我的问题是偶尔并非总是getHistoricalX()会引发异常。我附加了LogCat结果。

07-31 16:53:30.358: V/ZoomTextView(19540): onScroll()
07-31 16:53:30.358: E/InputEventReceiver(19540): Exception dispatching input event.
07-31 16:53:30.358: E/MessageQueue-JNI(19540): Exception in MessageQueue callback: handleReceiveCallback
07-31 16:53:30.358: E/MessageQueue-JNI(19540): java.lang.IllegalArgumentException: historyPos out of range
07-31 16:53:30.358: E/MessageQueue-JNI(19540):  at android.view.MotionEvent.nativeGetAxisValue(Native Method)
07-31 16:53:30.358: E/MessageQueue-JNI(19540):  at android.view.MotionEvent.getHistoricalX(MotionEvent.java:2739)

因为我知道有两个指针并且历史记录的大小至少为0,所以我不清楚这个异常是如何或为何发生的。有人可以帮忙吗?

我看到了this similar question,这对我毫无帮助。

2 个答案:

答案 0 :(得分:8)

在使用getHistoricalX()getHistoricalY()之前,您应该使用getHistorySize()检查尺寸。

如果返回零,则表示没有历史事件。然后,您只需使用getX()getY()处理当前事件。

答案 1 :(得分:1)

你有同样的问题,由于Geobits的回答,它得到了解决。只需检查getHistorySize()未返回0:

            if (event.getHistorySize() > 0) {

                float lastX = event.getHistoricalX(0);

            }