Merge "Support time, date, and datetime keyboard"

This commit is contained in:
Tadashi G. Takaoka 2012-03-01 21:24:01 -08:00 committed by Android (Google) Code Review
commit 3e52a10f4b
12 changed files with 169 additions and 72 deletions

View file

@ -115,6 +115,7 @@
<!-- U+207F: "ⁿ" SUPERSCRIPT LATIN SMALL LETTER N <!-- U+207F: "ⁿ" SUPERSCRIPT LATIN SMALL LETTER N
U+2205: "∅" EMPTY SET --> U+2205: "∅" EMPTY SET -->
<string name="more_keys_for_symbols_0">&#x207F;,&#x2205;</string> <string name="more_keys_for_symbols_0">&#x207F;,&#x2205;</string>
<string name="more_keys_for_am_pm">!fixedColumnOrder!2,!hasLabels!,\@string/label_time_am,\@string/label_time_pm</string>
<string name="settings_as_more_key">\@icon/settingsKey|\@integer/key_settings</string> <string name="settings_as_more_key">\@icon/settingsKey|\@integer/key_settings</string>
<string name="keylabel_for_comma">,</string> <string name="keylabel_for_comma">,</string>
<string name="more_keys_for_comma"></string> <string name="more_keys_for_comma"></string>

View file

@ -58,6 +58,10 @@
<!-- U+FF0A: "" FULLWIDTH ASTERISK <!-- U+FF0A: "" FULLWIDTH ASTERISK
U+FF03: "" FULLWIDTH NUMBER SIGN --> U+FF03: "" FULLWIDTH NUMBER SIGN -->
<string name="label_to_phone_symbols_key">&#xFF0A;&#xFF03;</string> <string name="label_to_phone_symbols_key">&#xFF0A;&#xFF03;</string>
<!-- Key label for "ante meridiem" -->
<string name="label_time_am">"AM"</string>
<!-- Key label for "post meridiem" -->
<string name="label_time_pm">"PM"</string>
<!-- Always show the suggestion strip --> <!-- Always show the suggestion strip -->
<string name="prefs_suggestion_visibility_show_value">0</string> <string name="prefs_suggestion_visibility_show_value">0</string>

View file

@ -63,10 +63,24 @@
latin:keyLabel="/" latin:keyLabel="/"
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"
latin:keyWidth="9.25%p" /> latin:keyWidth="9.25%p" />
<switch>
<case
latin:mode="time|datetime"
>
<Key
latin:keyLabel=","
latin:keyLabelFlags="hasPopupHint"
latin:moreKeys="@string/more_keys_for_am_pm"
latin:keyStyle="numKeyStyle"
latin:keyWidth="9.25%p" />
</case>
<default>
<Key <Key
latin:keyLabel="," latin:keyLabel=","
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"
latin:keyWidth="9.25%p" /> latin:keyWidth="9.25%p" />
</default>
</switch>
<Key <Key
latin:keyLabel="4" latin:keyLabel="4"
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"
@ -94,10 +108,22 @@
latin:keyLabel=")" latin:keyLabel=")"
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"
latin:keyWidth="9.25%p" /> latin:keyWidth="9.25%p" />
<switch>
<case
latin:mode="time|datetime"
>
<Key
latin:keyLabel=":"
latin:keyStyle="numKeyStyle"
latin:keyWidth="9.25%p" />
</case>
<default>
<Key <Key
latin:keyLabel="=" latin:keyLabel="="
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"
latin:keyWidth="9.25%p" /> latin:keyWidth="9.25%p" />
</default>
</switch>
<Key <Key
latin:keyLabel="7" latin:keyLabel="7"
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"

View file

@ -65,10 +65,24 @@
latin:keyLabel="/" latin:keyLabel="/"
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"
latin:keyWidth="8.047%p" /> latin:keyWidth="8.047%p" />
<switch>
<case
latin:mode="time|datetime"
>
<Key
latin:keyLabel=","
latin:keyLabelFlags="hasPopupHint"
latin:moreKeys="@string/more_keys_for_am_pm"
latin:keyStyle="numKeyStyle"
latin:keyWidth="8.047%p" />
</case>
<default>
<Key <Key
latin:keyLabel="," latin:keyLabel=","
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"
latin:keyWidth="8.047%p" /> latin:keyWidth="8.047%p" />
</default>
</switch>
<Key <Key
latin:keyLabel="4" latin:keyLabel="4"
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"
@ -96,10 +110,22 @@
latin:keyLabel=")" latin:keyLabel=")"
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"
latin:keyWidth="8.047%p" /> latin:keyWidth="8.047%p" />
<switch>
<case
latin:mode="time|datetime"
>
<Key
latin:keyLabel=":"
latin:keyStyle="numKeyStyle"
latin:keyWidth="8.047%p" />
</case>
<default>
<Key <Key
latin:keyLabel="=" latin:keyLabel="="
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"
latin:keyWidth="8.047%p" /> latin:keyWidth="8.047%p" />
</default>
</switch>
<Key <Key
latin:keyLabel="7" latin:keyLabel="7"
latin:keyStyle="numKeyStyle" latin:keyStyle="numKeyStyle"

View file

@ -41,9 +41,12 @@
latin:styleName="numberKeyStyle" latin:styleName="numberKeyStyle"
latin:keyLabelFlags="alignLeftOfCenter|hasHintLabel" latin:keyLabelFlags="alignLeftOfCenter|hasHintLabel"
latin:parentStyle="numKeyStyle" /> latin:parentStyle="numKeyStyle" />
<!-- U+0030: "0" DIGIT ZERO
U+002B: "+" PLUS SIGN -->
<key-style <key-style
latin:styleName="num0KeyStyle" latin:styleName="num0KeyStyle"
latin:code="48" latin:code="0x0030"
latin:altCode="0x002B"
latin:keyLabel="0 +" latin:keyLabel="0 +"
latin:keyActionFlags="enableLongPress" latin:keyActionFlags="enableLongPress"
latin:parentStyle="numberKeyStyle" /> latin:parentStyle="numberKeyStyle" />
@ -91,10 +94,11 @@
latin:keyLabel="9" latin:keyLabel="9"
latin:keyHintLabel="WXYZ" latin:keyHintLabel="WXYZ"
latin:parentStyle="numberKeyStyle" /> latin:parentStyle="numberKeyStyle" />
<!-- U+FF0A: "" FULLWIDTH ASTERISK --> <!-- U+002A: "*" ASTERISK
U+FF0A: "" FULLWIDTH ASTERISK -->
<key-style <key-style
latin:styleName="numStarKeyStyle" latin:styleName="numStarKeyStyle"
latin:code="42" latin:code="0x002A"
latin:keyLabel="&#xFF0A;" latin:keyLabel="&#xFF0A;"
latin:parentStyle="numKeyStyle" /> latin:parentStyle="numKeyStyle" />
<!-- Only for non-tablet device --> <!-- Only for non-tablet device -->
@ -108,15 +112,17 @@
latin:code="@integer/key_switch_alpha_symbol" latin:code="@integer/key_switch_alpha_symbol"
latin:keyLabel="@string/label_to_phone_numeric_key" latin:keyLabel="@string/label_to_phone_numeric_key"
latin:parentStyle="numModeKeyStyle" /> latin:parentStyle="numModeKeyStyle" />
<!-- U+002C: "," COMMA -->
<key-style <key-style
latin:styleName="numPauseKeyStyle" latin:styleName="numPauseKeyStyle"
latin:code="44" latin:code="0x002C"
latin:keyLabel="@string/label_pause_key" latin:keyLabel="@string/label_pause_key"
latin:keyLabelFlags="followKeyHintLabelRatio|autoXScale" latin:keyLabelFlags="followKeyHintLabelRatio|autoXScale"
latin:parentStyle="numKeyBaseStyle" /> latin:parentStyle="numKeyBaseStyle" />
<!-- U+003B: ";" SEMICOLON -->
<key-style <key-style
latin:styleName="numWaitKeyStyle" latin:styleName="numWaitKeyStyle"
latin:code="59" latin:code="0x003B"
latin:keyLabel="@string/label_wait_key" latin:keyLabel="@string/label_wait_key"
latin:keyLabelFlags="followKeyHintLabelRatio|autoXScale" latin:keyLabelFlags="followKeyHintLabelRatio|autoXScale"
latin:parentStyle="numKeyBaseStyle" /> latin:parentStyle="numKeyBaseStyle" />

View file

@ -46,10 +46,32 @@
<Key <Key
latin:keyLabel="6" latin:keyLabel="6"
latin:keyStyle="numKeyStyle" /> latin:keyStyle="numKeyStyle" />
<switch>
<case
latin:mode="date"
>
<Key
latin:keyLabel="."
latin:keyStyle="numFunctionalKeyStyle"
latin:keyWidth="fillRight" />
</case>
<case
latin:mode="time|datetime"
>
<Key
latin:keyLabel="."
latin:keyLabelFlags="hasPopupHint"
latin:moreKeys="@string/more_keys_for_am_pm"
latin:keyStyle="numFunctionalKeyStyle"
latin:keyWidth="fillRight" />
</case>
<default>
<Key <Key
latin:keyLabel="," latin:keyLabel=","
latin:keyStyle="numFunctionalKeyStyle" latin:keyStyle="numFunctionalKeyStyle"
latin:keyWidth="fillRight" /> latin:keyWidth="fillRight" />
</default>
</switch>
</Row> </Row>
<Row> <Row>
<Key <Key
@ -71,9 +93,39 @@
<Key <Key
latin:keyLabel="0" latin:keyLabel="0"
latin:keyStyle="numKeyStyle" /> latin:keyStyle="numKeyStyle" />
<switch>
<case
latin:mode="date"
>
<Key
latin:keyLabel="/"
latin:keyStyle="numKeyStyle" />
</case>
<case
latin:mode="time"
>
<Key
latin:keyLabel=":"
latin:keyStyle="numKeyStyle" />
</case>
<case
latin:mode="datetime"
>
<!-- U+002F: "/" SOLIDUS
U+003A: ":" COLON -->
<Key
latin:code="0x002F"
latin:altCode="0x003A"
latin:keyLabel="/ :"
latin:keyActionFlags="enableLongPress"
latin:keyStyle="numKeyStyle" />
</case>
<default>
<Key <Key
latin:keyLabel="." latin:keyLabel="."
latin:keyStyle="numKeyStyle" /> latin:keyStyle="numKeyStyle" />
</default>
</switch>
<Key <Key
latin:keyStyle="enterKeyStyle" latin:keyStyle="enterKeyStyle"
latin:keyWidth="fillRight" /> latin:keyWidth="fillRight" />

View file

@ -85,8 +85,6 @@ public class Keyboard {
public static final int CODE_CLOSING_SQUARE_BRACKET = ']'; public static final int CODE_CLOSING_SQUARE_BRACKET = ']';
public static final int CODE_CLOSING_CURLY_BRACKET = '}'; public static final int CODE_CLOSING_CURLY_BRACKET = '}';
public static final int CODE_CLOSING_ANGLE_BRACKET = '>'; public static final int CODE_CLOSING_ANGLE_BRACKET = '>';
public static final int CODE_DIGIT0 = '0';
public static final int CODE_PLUS = '+';
private static final int MINIMUM_LETTER_CODE = CODE_TAB; private static final int MINIMUM_LETTER_CODE = CODE_TAB;
/** Special keys code. Must be negative. /** Special keys code. Must be negative.
@ -184,19 +182,12 @@ public class Keyboard {
return null; return null;
} }
// TODO: Remove this method.
public boolean isShiftLocked() {
return mId.isAlphabetShiftLockedKeyboard();
}
// TODO: Remove this method. // TODO: Remove this method.
public boolean isShiftedOrShiftLocked() { public boolean isShiftedOrShiftLocked() {
return mId.isAlphabetShiftedOrShiftLockedKeyboard(); // Alphabet mode have unshifted, manual shifted, automatic shifted, shift locked, and
} // shift lock shifted element. So that unshifed element is the only one that is NOT in
// shifted or shift locked state.
// TODO: Remove this method. return mId.isAlphabetKeyboard() && mId.mElementId != KeyboardId.ELEMENT_ALPHABET;
public boolean isManualShifted() {
return mId.isAlphabetManualShiftedKeyboard();
} }
public static boolean isLetterCode(int code) { public static boolean isLetterCode(int code) {

View file

@ -36,6 +36,9 @@ public class KeyboardId {
public static final int MODE_IM = 3; public static final int MODE_IM = 3;
public static final int MODE_PHONE = 4; public static final int MODE_PHONE = 4;
public static final int MODE_NUMBER = 5; public static final int MODE_NUMBER = 5;
public static final int MODE_DATE = 6;
public static final int MODE_TIME = 7;
public static final int MODE_DATETIME = 8;
public static final int ELEMENT_ALPHABET = 0; public static final int ELEMENT_ALPHABET = 0;
public static final int ELEMENT_ALPHABET_MANUAL_SHIFTED = 1; public static final int ELEMENT_ALPHABET_MANUAL_SHIFTED = 1;
@ -123,31 +126,6 @@ public class KeyboardId {
return mElementId < ELEMENT_SYMBOLS; return mElementId < ELEMENT_SYMBOLS;
} }
public boolean isAlphabetShiftLockedKeyboard() {
return mElementId == ELEMENT_ALPHABET_SHIFT_LOCKED
|| mElementId == ELEMENT_ALPHABET_SHIFT_LOCK_SHIFTED;
}
public boolean isAlphabetShiftedOrShiftLockedKeyboard() {
return isAlphabetKeyboard() && mElementId != ELEMENT_ALPHABET;
}
public boolean isAlphabetManualShiftedKeyboard() {
return mElementId == ELEMENT_ALPHABET_MANUAL_SHIFTED;
}
public boolean isSymbolsKeyboard() {
return mElementId == ELEMENT_SYMBOLS || mElementId == ELEMENT_SYMBOLS_SHIFTED;
}
public boolean isPhoneKeyboard() {
return mElementId == ELEMENT_PHONE || mElementId == ELEMENT_PHONE_SYMBOLS;
}
public boolean isPhoneShiftKeyboard() {
return mElementId == ELEMENT_PHONE_SYMBOLS;
}
public boolean navigateNext() { public boolean navigateNext() {
return EditorInfoCompatUtils.hasFlagNavigateNext(mEditorInfo.imeOptions); return EditorInfoCompatUtils.hasFlagNavigateNext(mEditorInfo.imeOptions);
} }
@ -242,6 +220,9 @@ public class KeyboardId {
case MODE_IM: return "im"; case MODE_IM: return "im";
case MODE_PHONE: return "phone"; case MODE_PHONE: return "phone";
case MODE_NUMBER: return "number"; case MODE_NUMBER: return "number";
case MODE_DATE: return "date";
case MODE_TIME: return "time";
case MODE_DATETIME: return "datetime";
default: return null; default: return null;
} }
} }

View file

@ -131,6 +131,9 @@ public class KeyboardSet {
} }
break; break;
case KeyboardId.MODE_NUMBER: case KeyboardId.MODE_NUMBER:
case KeyboardId.MODE_DATE:
case KeyboardId.MODE_TIME:
case KeyboardId.MODE_DATETIME:
keyboardSetElementId = KeyboardId.ELEMENT_NUMBER; keyboardSetElementId = KeyboardId.ELEMENT_NUMBER;
break; break;
default: default:

View file

@ -849,7 +849,7 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
final KeyPreviewDrawParams params = mKeyPreviewDrawParams; final KeyPreviewDrawParams params = mKeyPreviewDrawParams;
final int keyDrawX = key.mX + key.mVisualInsetsLeft; final int keyDrawX = key.mX + key.mVisualInsetsLeft;
final int keyDrawWidth = key.mWidth - key.mVisualInsetsLeft - key.mVisualInsetsRight; final int keyDrawWidth = key.mWidth - key.mVisualInsetsLeft - key.mVisualInsetsRight;
// What we show as preview should match what we show on key top in onBufferDraw(). // What we show as preview should match what we show on a key top in onBufferDraw().
if (key.mLabel != null) { if (key.mLabel != null) {
// TODO Should take care of temporaryShiftLabel here. // TODO Should take care of temporaryShiftLabel here.
previewText.setCompoundDrawables(null, null, null, null); previewText.setCompoundDrawables(null, null, null, null);

View file

@ -481,11 +481,10 @@ public class LatinKeyboardView extends KeyboardView implements PointerTracker.Ke
*/ */
protected boolean onLongPress(Key parentKey, PointerTracker tracker) { protected boolean onLongPress(Key parentKey, PointerTracker tracker) {
final int primaryCode = parentKey.mCode; final int primaryCode = parentKey.mCode;
final Keyboard keyboard = getKeyboard(); if (parentKey.mAltCode != Keyboard.CODE_UNSPECIFIED) {
if (primaryCode == Keyboard.CODE_DIGIT0 && keyboard.mId.isPhoneKeyboard()) { // Long press on a key that has altCode defined.
tracker.onLongPressed(); tracker.onLongPressed();
// Long pressing on 0 in phone number keypad gives you a '+'. invokeCodeInput(parentKey.mAltCode);
invokeCodeInput(Keyboard.CODE_PLUS);
invokeReleaseKey(primaryCode); invokeReleaseKey(primaryCode);
KeyboardSwitcher.getInstance().hapticAndAudioFeedback(primaryCode); KeyboardSwitcher.getInstance().hapticAndAudioFeedback(primaryCode);
return true; return true;

View file

@ -563,8 +563,16 @@ public class Utils {
switch (inputType & InputType.TYPE_MASK_CLASS) { switch (inputType & InputType.TYPE_MASK_CLASS) {
case InputType.TYPE_CLASS_NUMBER: case InputType.TYPE_CLASS_NUMBER:
case InputType.TYPE_CLASS_DATETIME:
return KeyboardId.MODE_NUMBER; return KeyboardId.MODE_NUMBER;
case InputType.TYPE_CLASS_DATETIME:
switch (variation) {
case InputType.TYPE_DATETIME_VARIATION_DATE:
return KeyboardId.MODE_DATE;
case InputType.TYPE_DATETIME_VARIATION_TIME:
return KeyboardId.MODE_TIME;
default: // InputType.TYPE_DATETIME_VARIATION_NORMAL
return KeyboardId.MODE_DATETIME;
}
case InputType.TYPE_CLASS_PHONE: case InputType.TYPE_CLASS_PHONE:
return KeyboardId.MODE_PHONE; return KeyboardId.MODE_PHONE;
case InputType.TYPE_CLASS_TEXT: case InputType.TYPE_CLASS_TEXT: