aboutsummaryrefslogtreecommitdiffstats
path: root/java/src/com/android/inputmethod/latin/LatinKeyboardBaseView.java
diff options
context:
space:
mode:
authorTadashi G. Takaoka <takaoka@google.com>2010-09-29 04:17:36 +0900
committerTadashi G. Takaoka <takaoka@google.com>2010-09-29 12:36:13 +0900
commitafb353277928b9c13a97f2aefde7412f432e060a (patch)
treeaaa05096aeed5f46e3d2ced903b890046b426bdc /java/src/com/android/inputmethod/latin/LatinKeyboardBaseView.java
parent6e5a3986854549a45c95770b5a88ae5577e93299 (diff)
downloadlatinime-afb353277928b9c13a97f2aefde7412f432e060a.tar.gz
latinime-afb353277928b9c13a97f2aefde7412f432e060a.tar.xz
latinime-afb353277928b9c13a97f2aefde7412f432e060a.zip
Mini keyboard works even while shift is being pressed
Bug: 3038861 Change-Id: I94011ca80710ff6eb24e940104f7d9d3bb86840a
Diffstat (limited to 'java/src/com/android/inputmethod/latin/LatinKeyboardBaseView.java')
-rw-r--r--java/src/com/android/inputmethod/latin/LatinKeyboardBaseView.java14
1 files changed, 11 insertions, 3 deletions
diff --git a/java/src/com/android/inputmethod/latin/LatinKeyboardBaseView.java b/java/src/com/android/inputmethod/latin/LatinKeyboardBaseView.java
index 3761dab14..75ef691c8 100644
--- a/java/src/com/android/inputmethod/latin/LatinKeyboardBaseView.java
+++ b/java/src/com/android/inputmethod/latin/LatinKeyboardBaseView.java
@@ -205,6 +205,7 @@ public class LatinKeyboardBaseView extends View implements PointerTracker.UIProx
private long mMiniKeyboardPopupTime;
private int[] mWindowOffset;
private final float mMiniKeyboardSlideAllowance;
+ private int mMiniKeyboardTrackerId;
/** Listener for {@link OnKeyboardActionListener}. */
private OnKeyboardActionListener mKeyboardActionListener;
@@ -1023,6 +1024,7 @@ public class LatinKeyboardBaseView extends View implements PointerTracker.UIProx
if (result) {
dismissKeyPreview();
tracker.setAlreadyProcessed();
+ mMiniKeyboardTrackerId = tracker.mPointerId;
}
return result;
}
@@ -1258,9 +1260,15 @@ public class LatinKeyboardBaseView extends View implements PointerTracker.UIProx
// Needs to be called after the gesture detector gets a turn, as it may have
// displayed the mini keyboard
if (mMiniKeyboard != null) {
- MotionEvent translated = generateMiniKeyboardMotionEvent(action, x, y, eventTime);
- mMiniKeyboard.onTouchEvent(translated);
- translated.recycle();
+ final int miniKeyboardPointerIndex = me.findPointerIndex(mMiniKeyboardTrackerId);
+ if (miniKeyboardPointerIndex >= 0 && miniKeyboardPointerIndex < pointerCount) {
+ final int miniKeyboardX = (int)me.getX(miniKeyboardPointerIndex);
+ final int miniKeyboardY = (int)me.getY(miniKeyboardPointerIndex);
+ MotionEvent translated = generateMiniKeyboardMotionEvent(action,
+ miniKeyboardX, miniKeyboardY, eventTime);
+ mMiniKeyboard.onTouchEvent(translated);
+ translated.recycle();
+ }
return true;
}