Merge "Enforce serial ordering of MotionEvents." into gingerbread

This commit is contained in:
Jeff Brown
2010-09-23 14:51:52 -07:00
committed by Android (Google) Code Review
2 changed files with 48 additions and 20 deletions

View File

@@ -1876,6 +1876,9 @@ public final class ViewRoot extends Handler implements ViewParent,
deliverPointerEvent(event);
} finally {
event.recycle();
if (msg.arg1 != 0) {
finishInputEvent();
}
if (LOCAL_LOGV || WATCH_POINTER) Log.i(TAG, "Done dispatching!");
}
} break;
@@ -1885,6 +1888,9 @@ public final class ViewRoot extends Handler implements ViewParent,
deliverTrackballEvent(event);
} finally {
event.recycle();
if (msg.arg1 != 0) {
finishInputEvent();
}
}
} break;
case DISPATCH_APP_VISIBILITY:
@@ -2019,15 +2025,24 @@ public final class ViewRoot extends Handler implements ViewParent,
}
}
private void finishKeyEvent(KeyEvent event) {
if (LOCAL_LOGV) Log.v(TAG, "Telling window manager key is finished");
private void startInputEvent(Runnable finishedCallback) {
if (mFinishedCallback != null) {
Slog.w(TAG, "Received a new input event from the input queue but there is "
+ "already an unfinished input event in progress.");
}
mFinishedCallback = finishedCallback;
}
private void finishInputEvent() {
if (LOCAL_LOGV) Log.v(TAG, "Telling window manager input event is finished");
if (mFinishedCallback != null) {
mFinishedCallback.run();
mFinishedCallback = null;
} else {
Slog.w(TAG, "Attempted to tell the input queue that the current key event "
+ "is finished but there is no key event actually in progress.");
Slog.w(TAG, "Attempted to tell the input queue that the current input event "
+ "is finished but there is no input event actually in progress.");
}
}
@@ -2487,7 +2502,7 @@ public final class ViewRoot extends Handler implements ViewParent,
? mView.dispatchKeyEventPreIme(event) : true;
if (handled) {
if (sendDone) {
finishKeyEvent(event);
finishInputEvent();
}
return;
}
@@ -2518,7 +2533,7 @@ public final class ViewRoot extends Handler implements ViewParent,
deliverKeyEventToViewHierarchy(event, sendDone);
return;
} else if (sendDone) {
finishKeyEvent(event);
finishInputEvent();
} else {
Log.w(TAG, "handleFinishedEvent(seq=" + seq
+ " handled=" + handled + " ev=" + event
@@ -2591,7 +2606,7 @@ public final class ViewRoot extends Handler implements ViewParent,
} finally {
if (sendDone) {
finishKeyEvent(event);
finishInputEvent();
}
// Let the exception fall through -- the looper will catch
// it and take care of the bad app for us.
@@ -2774,20 +2789,13 @@ public final class ViewRoot extends Handler implements ViewParent,
private final InputHandler mInputHandler = new InputHandler() {
public void handleKey(KeyEvent event, Runnable finishedCallback) {
if (mFinishedCallback != null) {
Slog.w(TAG, "Received a new key event from the input queue but there is "
+ "already an unfinished key event in progress.");
}
mFinishedCallback = finishedCallback;
startInputEvent(finishedCallback);
dispatchKey(event, true);
}
public void handleMotion(MotionEvent event, Runnable finishedCallback) {
finishedCallback.run();
dispatchMotion(event);
startInputEvent(finishedCallback);
dispatchMotion(event, true);
}
};
@@ -2820,26 +2828,43 @@ public final class ViewRoot extends Handler implements ViewParent,
}
public void dispatchMotion(MotionEvent event) {
dispatchMotion(event, false);
}
private void dispatchMotion(MotionEvent event, boolean sendDone) {
int source = event.getSource();
if ((source & InputDevice.SOURCE_CLASS_POINTER) != 0) {
dispatchPointer(event);
dispatchPointer(event, sendDone);
} else if ((source & InputDevice.SOURCE_CLASS_TRACKBALL) != 0) {
dispatchTrackball(event);
dispatchTrackball(event, sendDone);
} else {
// TODO
Log.v(TAG, "Dropping unsupported motion event (unimplemented): " + event);
if (sendDone) {
finishInputEvent();
}
}
}
public void dispatchPointer(MotionEvent event) {
dispatchPointer(event, false);
}
private void dispatchPointer(MotionEvent event, boolean sendDone) {
Message msg = obtainMessage(DISPATCH_POINTER);
msg.obj = event;
msg.arg1 = sendDone ? 1 : 0;
sendMessageAtTime(msg, event.getEventTime());
}
public void dispatchTrackball(MotionEvent event) {
dispatchTrackball(event, false);
}
private void dispatchTrackball(MotionEvent event, boolean sendDone) {
Message msg = obtainMessage(DISPATCH_TRACKBALL);
msg.obj = event;
msg.arg1 = sendDone ? 1 : 0;
sendMessageAtTime(msg, event.getEventTime());
}

View File

@@ -232,8 +232,11 @@ public class PhoneWindowManager implements WindowManagerPolicy {
@Override
public void handleMotion(MotionEvent event, Runnable finishedCallback) {
finishedCallback.run();
synchronized (mLock) {
mPointerLocationView.addTouchEvent(event);
if (mPointerLocationView != null) {
mPointerLocationView.addTouchEvent(event);
}
}
}
};