Disable functional key while in sliding input mode
This change registers the functional key when sliding input mode is end at the functional key itself. Bug: 8915171 Change-Id: I2031e2aa4ebf33684221fc44d4a808112489724f
This commit is contained in:
parent
0efd8d1b69
commit
e3b1bdc4f1
1 changed files with 7 additions and 4 deletions
|
@ -1168,6 +1168,7 @@ public final class PointerTracker implements PointerTrackerQueue.Element {
|
||||||
|
|
||||||
private void onUpEventInternal(final int x, final int y, final long eventTime) {
|
private void onUpEventInternal(final int x, final int y, final long eventTime) {
|
||||||
mTimerProxy.cancelKeyTimers();
|
mTimerProxy.cancelKeyTimers();
|
||||||
|
final boolean isInSlidingKeyInput = mIsInSlidingKeyInput;
|
||||||
resetSlidingKeyInput();
|
resetSlidingKeyInput();
|
||||||
mIsDetectingGesture = false;
|
mIsDetectingGesture = false;
|
||||||
final Key currentKey = mCurrentKey;
|
final Key currentKey = mCurrentKey;
|
||||||
|
@ -1197,9 +1198,11 @@ public final class PointerTracker implements PointerTrackerQueue.Element {
|
||||||
if (mIsTrackingForActionDisabled) {
|
if (mIsTrackingForActionDisabled) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (currentKey != null && !currentKey.isRepeatable()) {
|
if (currentKey != null && currentKey.isRepeatable() && !isInSlidingKeyInput) {
|
||||||
detectAndSendKey(currentKey, mKeyX, mKeyY, eventTime);
|
// Repeatable key has been registered in {@link #onDownEventInternal(int,int,long)}.
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
detectAndSendKey(currentKey, mKeyX, mKeyY, eventTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onShowMoreKeysPanel(final int translatedX, final int translatedY,
|
public void onShowMoreKeysPanel(final int translatedX, final int translatedY,
|
||||||
|
@ -1251,7 +1254,7 @@ public final class PointerTracker implements PointerTrackerQueue.Element {
|
||||||
if (key == null) return;
|
if (key == null) return;
|
||||||
if (!key.isRepeatable()) return;
|
if (!key.isRepeatable()) return;
|
||||||
// Don't start key repeat when we are in sliding input mode.
|
// Don't start key repeat when we are in sliding input mode.
|
||||||
if (mIsInSlidingKeyInputFromModifier) return;
|
if (mIsInSlidingKeyInput) return;
|
||||||
onRegisterKey(key);
|
onRegisterKey(key);
|
||||||
mTimerProxy.startKeyRepeatTimer(this);
|
mTimerProxy.startKeyRepeatTimer(this);
|
||||||
}
|
}
|
||||||
|
@ -1313,7 +1316,7 @@ public final class PointerTracker implements PointerTrackerQueue.Element {
|
||||||
// doesn't have its more keys. (e.g. spacebar, globe key)
|
// doesn't have its more keys. (e.g. spacebar, globe key)
|
||||||
// We always need to start the long press timer if the key has its more keys regardless of
|
// We always need to start the long press timer if the key has its more keys regardless of
|
||||||
// whether or not we are in the sliding input mode.
|
// whether or not we are in the sliding input mode.
|
||||||
if (mIsInSlidingKeyInputFromModifier && key.mMoreKeys == null) return;
|
if (mIsInSlidingKeyInput && key.mMoreKeys == null) return;
|
||||||
mTimerProxy.startLongPressTimer(this);
|
mTimerProxy.startLongPressTimer(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue