Skip to content
Snippets Groups Projects
Commit ab41391c authored by Tadashi G. Takaoka's avatar Tadashi G. Takaoka Committed by Android (Google) Code Review
Browse files

Merge "Merge PointerTrackerKeyState into PointerTracker"

parents 41f15093 8a995157
No related branches found
No related tags found
No related merge requests found
...@@ -23,7 +23,6 @@ import android.util.Log; ...@@ -23,7 +23,6 @@ import android.util.Log;
import android.view.MotionEvent; import android.view.MotionEvent;
import com.android.inputmethod.keyboard.LatinKeyboardBaseView.KeyTimerHandler; import com.android.inputmethod.keyboard.LatinKeyboardBaseView.KeyTimerHandler;
import com.android.inputmethod.keyboard.internal.PointerTrackerKeyState;
import com.android.inputmethod.keyboard.internal.PointerTrackerQueue; import com.android.inputmethod.keyboard.internal.PointerTrackerQueue;
import com.android.inputmethod.latin.LatinImeLogger; import com.android.inputmethod.latin.LatinImeLogger;
import com.android.inputmethod.latin.R; import com.android.inputmethod.latin.R;
...@@ -68,7 +67,19 @@ public class PointerTracker { ...@@ -68,7 +67,19 @@ public class PointerTracker {
private List<Key> mKeys; private List<Key> mKeys;
private int mKeyQuarterWidthSquared; private int mKeyQuarterWidthSquared;
private final PointerTrackerKeyState mKeyState; // The position and time at which first down event occurred.
private long mDownTime;
private long mUpTime;
// The current key index where this pointer is.
private int mKeyIndex = KeyDetector.NOT_A_KEY;
// The position where mKeyIndex was recognized for the first time.
private int mKeyX;
private int mKeyY;
// Last pointer position.
private int mLastX;
private int mLastY;
// true if keyboard layout has been changed. // true if keyboard layout has been changed.
private boolean mKeyboardLayoutHasBeenChanged; private boolean mKeyboardLayoutHasBeenChanged;
...@@ -116,7 +127,6 @@ public class PointerTracker { ...@@ -116,7 +127,6 @@ public class PointerTracker {
mDrawingProxy = drawingProxy; mDrawingProxy = drawingProxy;
mKeyTimerHandler = keyTimerHandler; mKeyTimerHandler = keyTimerHandler;
mPointerTrackerQueue = queue; // This is null for non-distinct multi-touch device. mPointerTrackerQueue = queue; // This is null for non-distinct multi-touch device.
mKeyState = new PointerTrackerKeyState(keyDetector);
setKeyDetectorInner(keyDetector); setKeyDetectorInner(keyDetector);
mKeyboardSwitcher = KeyboardSwitcher.getInstance(); mKeyboardSwitcher = KeyboardSwitcher.getInstance();
final Resources res = context.getResources(); final Resources res = context.getResources();
...@@ -197,7 +207,6 @@ public class PointerTracker { ...@@ -197,7 +207,6 @@ public class PointerTracker {
mKeyDetector = keyDetector; mKeyDetector = keyDetector;
mKeyboard = keyDetector.getKeyboard(); mKeyboard = keyDetector.getKeyboard();
mKeys = mKeyboard.getKeys(); mKeys = mKeyboard.getKeys();
mKeyState.setKeyDetector(keyDetector);
final int keyQuarterWidth = mKeyboard.getKeyWidth() / 4; final int keyQuarterWidth = mKeyboard.getKeyWidth() / 4;
mKeyQuarterWidthSquared = keyQuarterWidth * keyQuarterWidth; mKeyQuarterWidthSquared = keyQuarterWidth * keyQuarterWidth;
} }
...@@ -233,7 +242,7 @@ public class PointerTracker { ...@@ -233,7 +242,7 @@ public class PointerTracker {
} }
public boolean isModifier() { public boolean isModifier() {
return isModifierInternal(mKeyState.getKeyIndex()); return isModifierInternal(mKeyIndex);
} }
private boolean isOnModifierKey(int x, int y) { private boolean isOnModifierKey(int x, int y) {
...@@ -255,7 +264,7 @@ public class PointerTracker { ...@@ -255,7 +264,7 @@ public class PointerTracker {
} }
public void setReleasedKeyGraphics() { public void setReleasedKeyGraphics() {
setReleasedKeyGraphics(mKeyState.getKeyIndex()); setReleasedKeyGraphics(mKeyIndex);
} }
private void setReleasedKeyGraphics(int keyIndex) { private void setReleasedKeyGraphics(int keyIndex) {
...@@ -274,6 +283,46 @@ public class PointerTracker { ...@@ -274,6 +283,46 @@ public class PointerTracker {
} }
} }
public int getLastX() {
return mLastX;
}
public int getLastY() {
return mLastY;
}
public long getDownTime() {
return mDownTime;
}
private int onDownKey(int x, int y, long eventTime) {
mDownTime = eventTime;
return onMoveToNewKey(onMoveKeyInternal(x, y), x, y);
}
private int onMoveKeyInternal(int x, int y) {
mLastX = x;
mLastY = y;
return mKeyDetector.getKeyIndexAndNearbyCodes(x, y, null);
}
private int onMoveKey(int x, int y) {
return onMoveKeyInternal(x, y);
}
private int onMoveToNewKey(int keyIndex, int x, int y) {
mKeyIndex = keyIndex;
mKeyX = x;
mKeyY = y;
return keyIndex;
}
private int onUpKey(int x, int y, long eventTime) {
mUpTime = eventTime;
mKeyIndex = KeyDetector.NOT_A_KEY;
return onMoveKeyInternal(x, y);
}
public void onTouchEvent(int action, int x, int y, long eventTime) { public void onTouchEvent(int action, int x, int y, long eventTime) {
switch (action) { switch (action) {
case MotionEvent.ACTION_MOVE: case MotionEvent.ACTION_MOVE:
...@@ -298,10 +347,10 @@ public class PointerTracker { ...@@ -298,10 +347,10 @@ public class PointerTracker {
printTouchEvent("onDownEvent:", x, y, eventTime); printTouchEvent("onDownEvent:", x, y, eventTime);
// Naive up-to-down noise filter. // Naive up-to-down noise filter.
final long deltaT = eventTime - mKeyState.getUpTime(); final long deltaT = eventTime - mUpTime;
if (deltaT < mTouchNoiseThresholdMillis) { if (deltaT < mTouchNoiseThresholdMillis) {
final int dx = x - mKeyState.getLastX(); final int dx = x - mLastX;
final int dy = y - mKeyState.getLastY(); final int dy = y - mLastY;
final int distanceSquared = (dx * dx + dy * dy); final int distanceSquared = (dx * dx + dy * dy);
if (distanceSquared < mTouchNoiseThresholdDistanceSquared) { if (distanceSquared < mTouchNoiseThresholdDistanceSquared) {
if (DEBUG_MODE) if (DEBUG_MODE)
...@@ -325,7 +374,7 @@ public class PointerTracker { ...@@ -325,7 +374,7 @@ public class PointerTracker {
} }
private void onDownEventInternal(int x, int y, long eventTime) { private void onDownEventInternal(int x, int y, long eventTime) {
int keyIndex = mKeyState.onDownKey(x, y, eventTime); int keyIndex = onDownKey(x, y, eventTime);
// Sliding key is allowed when 1) enabled by configuration, 2) this pointer starts sliding // Sliding key is allowed when 1) enabled by configuration, 2) this pointer starts sliding
// from modifier key, or 3) this pointer is on mini-keyboard. // from modifier key, or 3) this pointer is on mini-keyboard.
mIsAllowedSlidingKeyInput = mConfigSlidingKeyInputEnabled || isModifierInternal(keyIndex) mIsAllowedSlidingKeyInput = mConfigSlidingKeyInputEnabled || isModifierInternal(keyIndex)
...@@ -341,7 +390,7 @@ public class PointerTracker { ...@@ -341,7 +390,7 @@ public class PointerTracker {
// {@link #setKeyboard}. In those cases, we should update keyIndex according to the new // {@link #setKeyboard}. In those cases, we should update keyIndex according to the new
// keyboard layout. // keyboard layout.
if (callListenerOnPressAndCheckKeyboardLayoutChange(getKey(keyIndex), false)) if (callListenerOnPressAndCheckKeyboardLayoutChange(getKey(keyIndex), false))
keyIndex = mKeyState.onDownKey(x, y, eventTime); keyIndex = onDownKey(x, y, eventTime);
startRepeatKey(keyIndex); startRepeatKey(keyIndex);
startLongPressTimer(keyIndex); startLongPressTimer(keyIndex);
...@@ -361,19 +410,18 @@ public class PointerTracker { ...@@ -361,19 +410,18 @@ public class PointerTracker {
printTouchEvent("onMoveEvent:", x, y, eventTime); printTouchEvent("onMoveEvent:", x, y, eventTime);
if (mKeyAlreadyProcessed) if (mKeyAlreadyProcessed)
return; return;
final PointerTrackerKeyState keyState = mKeyState;
// TODO: Remove this hacking code // TODO: Remove this hacking code
if (mIsInSlidingLanguageSwitch) { if (mIsInSlidingLanguageSwitch) {
((LatinKeyboard)mKeyboard).updateSpacebarPreviewIcon(x - keyState.getKeyX()); ((LatinKeyboard)mKeyboard).updateSpacebarPreviewIcon(x - mKeyX);
showKeyPreview(mSpaceKeyIndex); showKeyPreview(mSpaceKeyIndex);
return; return;
} }
final int lastX = keyState.getLastX(); final int lastX = mLastX;
final int lastY = keyState.getLastY(); final int lastY = mLastY;
final int oldKeyIndex = keyState.getKeyIndex(); final int oldKeyIndex = mKeyIndex;
final Key oldKey = getKey(oldKeyIndex); final Key oldKey = getKey(oldKeyIndex);
int keyIndex = keyState.onMoveKey(x, y); int keyIndex = onMoveKey(x, y);
if (isValidKeyIndex(keyIndex)) { if (isValidKeyIndex(keyIndex)) {
if (oldKey == null) { if (oldKey == null) {
// The pointer has been slid in to the new key, but the finger was not on any keys. // The pointer has been slid in to the new key, but the finger was not on any keys.
...@@ -382,8 +430,8 @@ public class PointerTracker { ...@@ -382,8 +430,8 @@ public class PointerTracker {
// {@link #setKeyboard}. In those cases, we should update keyIndex according to the // {@link #setKeyboard}. In those cases, we should update keyIndex according to the
// new keyboard layout. // new keyboard layout.
if (callListenerOnPressAndCheckKeyboardLayoutChange(getKey(keyIndex), true)) if (callListenerOnPressAndCheckKeyboardLayoutChange(getKey(keyIndex), true))
keyIndex = keyState.onMoveKey(x, y); keyIndex = onMoveKey(x, y);
keyState.onMoveToNewKey(keyIndex, x, y); onMoveToNewKey(keyIndex, x, y);
startLongPressTimer(keyIndex); startLongPressTimer(keyIndex);
showKeyPreview(keyIndex); showKeyPreview(keyIndex);
setPressedKeyGraphics(keyIndex); setPressedKeyGraphics(keyIndex);
...@@ -401,8 +449,8 @@ public class PointerTracker { ...@@ -401,8 +449,8 @@ public class PointerTracker {
// at {@link #setKeyboard}. In those cases, we should update keyIndex according // at {@link #setKeyboard}. In those cases, we should update keyIndex according
// to the new keyboard layout. // to the new keyboard layout.
if (callListenerOnPressAndCheckKeyboardLayoutChange(getKey(keyIndex), true)) if (callListenerOnPressAndCheckKeyboardLayoutChange(getKey(keyIndex), true))
keyIndex = keyState.onMoveKey(x, y); keyIndex = onMoveKey(x, y);
keyState.onMoveToNewKey(keyIndex, x, y); onMoveToNewKey(keyIndex, x, y);
startLongPressTimer(keyIndex); startLongPressTimer(keyIndex);
setPressedKeyGraphics(keyIndex); setPressedKeyGraphics(keyIndex);
showKeyPreview(keyIndex); showKeyPreview(keyIndex);
...@@ -432,7 +480,7 @@ public class PointerTracker { ...@@ -432,7 +480,7 @@ public class PointerTracker {
final LatinKeyboard keyboard = ((LatinKeyboard)mKeyboard); final LatinKeyboard keyboard = ((LatinKeyboard)mKeyboard);
if (mSubtypeSwitcher.useSpacebarLanguageSwitcher() if (mSubtypeSwitcher.useSpacebarLanguageSwitcher()
&& mSubtypeSwitcher.getEnabledKeyboardLocaleCount() > 1) { && mSubtypeSwitcher.getEnabledKeyboardLocaleCount() > 1) {
final int diff = x - keyState.getKeyX(); final int diff = x - mKeyX;
if (keyboard.shouldTriggerSpacebarSlidingLanguageSwitch(diff)) { if (keyboard.shouldTriggerSpacebarSlidingLanguageSwitch(diff)) {
// Detect start sliding language switch. // Detect start sliding language switch.
mIsInSlidingLanguageSwitch = true; mIsInSlidingLanguageSwitch = true;
...@@ -455,7 +503,7 @@ public class PointerTracker { ...@@ -455,7 +503,7 @@ public class PointerTracker {
startSlidingKeyInput(oldKey); startSlidingKeyInput(oldKey);
mKeyTimerHandler.cancelLongPressTimers(); mKeyTimerHandler.cancelLongPressTimers();
if (mIsAllowedSlidingKeyInput) { if (mIsAllowedSlidingKeyInput) {
keyState.onMoveToNewKey(keyIndex, x, y); onMoveToNewKey(keyIndex, x, y);
} else { } else {
mKeyAlreadyProcessed = true; mKeyAlreadyProcessed = true;
dismissKeyPreview(); dismissKeyPreview();
...@@ -497,17 +545,16 @@ public class PointerTracker { ...@@ -497,17 +545,16 @@ public class PointerTracker {
mKeyTimerHandler.cancelKeyTimers(); mKeyTimerHandler.cancelKeyTimers();
mDrawingProxy.cancelShowKeyPreview(this); mDrawingProxy.cancelShowKeyPreview(this);
mIsInSlidingKeyInput = false; mIsInSlidingKeyInput = false;
final PointerTrackerKeyState keyState = mKeyState;
final int keyX, keyY; final int keyX, keyY;
if (isMajorEnoughMoveToBeOnNewKey(x, y, keyState.onMoveKey(x, y))) { if (isMajorEnoughMoveToBeOnNewKey(x, y, onMoveKey(x, y))) {
keyX = x; keyX = x;
keyY = y; keyY = y;
} else { } else {
// Use previous fixed key coordinates. // Use previous fixed key coordinates.
keyX = keyState.getKeyX(); keyX = mKeyX;
keyY = keyState.getKeyY(); keyY = mKeyY;
} }
final int keyIndex = keyState.onUpKey(keyX, keyY, eventTime); final int keyIndex = onUpKey(keyX, keyY, eventTime);
dismissKeyPreview(); dismissKeyPreview();
if (updateReleasedKeyGraphics) if (updateReleasedKeyGraphics)
setReleasedKeyGraphics(keyIndex); setReleasedKeyGraphics(keyIndex);
...@@ -558,7 +605,7 @@ public class PointerTracker { ...@@ -558,7 +605,7 @@ public class PointerTracker {
mKeyTimerHandler.cancelKeyTimers(); mKeyTimerHandler.cancelKeyTimers();
mDrawingProxy.cancelShowKeyPreview(this); mDrawingProxy.cancelShowKeyPreview(this);
dismissKeyPreview(); dismissKeyPreview();
setReleasedKeyGraphics(mKeyState.getKeyIndex()); setReleasedKeyGraphics(mKeyIndex);
mIsInSlidingKeyInput = false; mIsInSlidingKeyInput = false;
} }
...@@ -581,22 +628,10 @@ public class PointerTracker { ...@@ -581,22 +628,10 @@ public class PointerTracker {
} }
} }
public int getLastX() {
return mKeyState.getLastX();
}
public int getLastY() {
return mKeyState.getLastY();
}
public long getDownTime() {
return mKeyState.getDownTime();
}
private boolean isMajorEnoughMoveToBeOnNewKey(int x, int y, int newKey) { private boolean isMajorEnoughMoveToBeOnNewKey(int x, int y, int newKey) {
if (mKeys == null || mKeyDetector == null) if (mKeys == null || mKeyDetector == null)
throw new NullPointerException("keyboard and/or key detector not set"); throw new NullPointerException("keyboard and/or key detector not set");
int curKey = mKeyState.getKeyIndex(); int curKey = mKeyIndex;
if (newKey == curKey) { if (newKey == curKey) {
return false; return false;
} else if (isValidKeyIndex(curKey)) { } else if (isValidKeyIndex(curKey)) {
......
/*
* Copyright (C) 2010 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.android.inputmethod.keyboard.internal;
import com.android.inputmethod.keyboard.KeyDetector;
import com.android.inputmethod.keyboard.PointerTracker;
/**
* This class keeps track of a key index and a position where {@link PointerTracker} is.
*/
public class PointerTrackerKeyState {
private KeyDetector mKeyDetector;
// The position and time at which first down event occurred.
private long mDownTime;
private long mUpTime;
// The current key index where this pointer is.
private int mKeyIndex = KeyDetector.NOT_A_KEY;
// The position where mKeyIndex was recognized for the first time.
private int mKeyX;
private int mKeyY;
// Last pointer position.
private int mLastX;
private int mLastY;
public PointerTrackerKeyState(KeyDetector keyDetector) {
if (keyDetector == null)
throw new NullPointerException();
mKeyDetector = keyDetector;
}
public void setKeyDetector(KeyDetector keyDetector) {
mKeyDetector = keyDetector;
}
public int getKeyIndex() {
return mKeyIndex;
}
public int getKeyX() {
return mKeyX;
}
public int getKeyY() {
return mKeyY;
}
public long getDownTime() {
return mDownTime;
}
public long getUpTime() {
return mUpTime;
}
public int getLastX() {
return mLastX;
}
public int getLastY() {
return mLastY;
}
public int onDownKey(int x, int y, long eventTime) {
mDownTime = eventTime;
return onMoveToNewKey(onMoveKeyInternal(x, y), x, y);
}
private int onMoveKeyInternal(int x, int y) {
mLastX = x;
mLastY = y;
return mKeyDetector.getKeyIndexAndNearbyCodes(x, y, null);
}
public int onMoveKey(int x, int y) {
return onMoveKeyInternal(x, y);
}
public int onMoveToNewKey(int keyIndex, int x, int y) {
mKeyIndex = keyIndex;
mKeyX = x;
mKeyY = y;
return keyIndex;
}
public int onUpKey(int x, int y, long eventTime) {
mUpTime = eventTime;
mKeyIndex = KeyDetector.NOT_A_KEY;
return onMoveKeyInternal(x, y);
}
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment