aboutsummaryrefslogtreecommitdiffstats
path: root/java/src/com/android/inputmethod/latin/ShiftKeyState.java
diff options
context:
space:
mode:
authorTadashi G. Takaoka <takaoka@google.com>2010-11-13 00:16:34 -0800
committerTadashi G. Takaoka <takaoka@google.com>2010-11-18 19:32:59 -0800
commitf27364600c742509b48857e6b8f17312033e0dc7 (patch)
treea07e3d98753fac073d34a643957204beaadcd4c4 /java/src/com/android/inputmethod/latin/ShiftKeyState.java
parent1d2d3228a393b3c562226936e3523eed4894def4 (diff)
downloadlatinime-f27364600c742509b48857e6b8f17312033e0dc7.tar.gz
latinime-f27364600c742509b48857e6b8f17312033e0dc7.tar.xz
latinime-f27364600c742509b48857e6b8f17312033e0dc7.zip
Implement both automatic and manual temporary upper cases
With this change, - Shift and Shift lock state of keyboard is maintained by LatinKeyboard.ShiftState. - Shift key state is maintained by ShiftKeyState object in KeyboardSwitcher. - LatinIME informs KeyboardSwitcher that shift key press, release and long press and KeyboardSwitcher determines which state LatinKeyboard and ShiftLeyState should be. Bug: 3193390 Change-Id: I948ef26fda512eb1cb0ebddc89d322c4f4f4d670
Diffstat (limited to 'java/src/com/android/inputmethod/latin/ShiftKeyState.java')
-rw-r--r--java/src/com/android/inputmethod/latin/ShiftKeyState.java25
1 files changed, 25 insertions, 0 deletions
diff --git a/java/src/com/android/inputmethod/latin/ShiftKeyState.java b/java/src/com/android/inputmethod/latin/ShiftKeyState.java
index 5312ce2cc..ef13ddc9b 100644
--- a/java/src/com/android/inputmethod/latin/ShiftKeyState.java
+++ b/java/src/com/android/inputmethod/latin/ShiftKeyState.java
@@ -16,21 +16,33 @@
package com.android.inputmethod.latin;
+import android.util.Log;
+
public class ShiftKeyState extends ModifierKeyState {
private static final int PRESSING_ON_SHIFTED = 3; // both temporary shifted & shift locked
private static final int IGNORING = 4;
+ public ShiftKeyState(String name) {
+ super(name);
+ }
+
@Override
public void onOtherKeyPressed() {
+ int oldState = mState;
if (mState == PRESSING) {
mState = MOMENTARY;
} else if (mState == PRESSING_ON_SHIFTED) {
mState = IGNORING;
}
+ if (DEBUG)
+ Log.d(TAG, mName + ".onOtherKeyPressed: " + toString(oldState) + " > " + this);
}
public void onPressOnShifted() {
+ int oldState = mState;
mState = PRESSING_ON_SHIFTED;
+ if (DEBUG)
+ Log.d(TAG, mName + ".onPressOnShifted: " + toString(oldState) + " > " + this);
}
public boolean isPressingOnShifted() {
@@ -40,4 +52,17 @@ public class ShiftKeyState extends ModifierKeyState {
public boolean isIgnoring() {
return mState == IGNORING;
}
+
+ @Override
+ public String toString() {
+ return toString(mState);
+ }
+
+ protected static String toString(int state) {
+ switch (state) {
+ case PRESSING_ON_SHIFTED: return "PRESSING_ON_SHIFTED";
+ case IGNORING: return "IGNORING";
+ default: return ModifierKeyState.toString(state);
+ }
+ }
}