Merge "All keys should be processed before processing modifier key" into gingerbread
This commit is contained in:
commit
bf1f16f35f
2 changed files with 40 additions and 8 deletions
|
@ -345,7 +345,7 @@ public class LatinKeyboardBaseView extends View implements PointerTracker.UIProx
|
|||
return -1;
|
||||
}
|
||||
|
||||
public void releasePointersOlderThan(PointerTracker tracker, long eventTime) {
|
||||
public void releaseAllPointersOlderThan(PointerTracker tracker, long eventTime) {
|
||||
LinkedList<PointerTracker> queue = mQueue;
|
||||
int oldestPos = 0;
|
||||
for (PointerTracker t = queue.get(oldestPos); t != tracker; t = queue.get(oldestPos)) {
|
||||
|
@ -353,11 +353,24 @@ public class LatinKeyboardBaseView extends View implements PointerTracker.UIProx
|
|||
oldestPos++;
|
||||
} else {
|
||||
t.onUpEvent(t.getLastX(), t.getLastY(), eventTime);
|
||||
t.setAlreadyProcessed();
|
||||
queue.remove(oldestPos);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void releaseAllPointersExcept(PointerTracker tracker, long eventTime) {
|
||||
for (PointerTracker t : mQueue) {
|
||||
if (t == tracker)
|
||||
continue;
|
||||
t.onUpEvent(t.getLastX(), t.getLastY(), eventTime);
|
||||
t.setAlreadyProcessed();
|
||||
}
|
||||
mQueue.clear();
|
||||
if (tracker != null)
|
||||
mQueue.add(tracker);
|
||||
}
|
||||
|
||||
public void remove(PointerTracker tracker) {
|
||||
mQueue.remove(tracker);
|
||||
}
|
||||
|
@ -1246,17 +1259,28 @@ public class LatinKeyboardBaseView extends View implements PointerTracker.UIProx
|
|||
}
|
||||
|
||||
private void onDownEvent(PointerTracker tracker, int x, int y, long eventTime) {
|
||||
if (tracker.isOnModifierKey(x, y)) {
|
||||
// Before processing a down event of modifier key, all pointers already being tracked
|
||||
// should be released.
|
||||
mPointerQueue.releaseAllPointersExcept(null, eventTime);
|
||||
}
|
||||
tracker.onDownEvent(x, y, eventTime);
|
||||
mPointerQueue.add(tracker);
|
||||
}
|
||||
|
||||
private void onUpEvent(PointerTracker tracker, int x, int y, long eventTime) {
|
||||
int index = mPointerQueue.lastIndexOf(tracker);
|
||||
if (index >= 0) {
|
||||
mPointerQueue.releasePointersOlderThan(tracker, eventTime);
|
||||
if (tracker.isModifier()) {
|
||||
// Before processing an up event of modifier key, all pointers already being tracked
|
||||
// should be released.
|
||||
mPointerQueue.releaseAllPointersExcept(tracker, eventTime);
|
||||
} else {
|
||||
Log.w(TAG, "onUpEvent: corresponding down event not found for pointer "
|
||||
+ tracker.mPointerId);
|
||||
int index = mPointerQueue.lastIndexOf(tracker);
|
||||
if (index >= 0) {
|
||||
mPointerQueue.releaseAllPointersOlderThan(tracker, eventTime);
|
||||
} else {
|
||||
Log.w(TAG, "onUpEvent: corresponding down event not found for pointer "
|
||||
+ tracker.mPointerId);
|
||||
}
|
||||
}
|
||||
tracker.onUpEvent(x, y, eventTime);
|
||||
mPointerQueue.remove(tracker);
|
||||
|
|
|
@ -123,8 +123,8 @@ public class PointerTracker {
|
|||
return isValidKeyIndex(keyIndex) ? mKeys[keyIndex] : null;
|
||||
}
|
||||
|
||||
public boolean isModifier() {
|
||||
Key key = getKey(mCurrentKey);
|
||||
private boolean isModifierInternal(int keyIndex) {
|
||||
Key key = getKey(keyIndex);
|
||||
if (key == null)
|
||||
return false;
|
||||
int primaryCode = key.codes[0];
|
||||
|
@ -132,6 +132,14 @@ public class PointerTracker {
|
|||
|| primaryCode == Keyboard.KEYCODE_MODE_CHANGE;
|
||||
}
|
||||
|
||||
public boolean isModifier() {
|
||||
return isModifierInternal(mCurrentKey);
|
||||
}
|
||||
|
||||
public boolean isOnModifierKey(int x, int y) {
|
||||
return isModifierInternal(mKeyDetector.getKeyIndexAndNearbyCodes(x, y, null));
|
||||
}
|
||||
|
||||
public void updateKey(int keyIndex) {
|
||||
if (mKeyAlreadyProcessed)
|
||||
return;
|
||||
|
|
Loading…
Reference in a new issue