2012-04-19 03:42:13 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2012 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.latin;
|
|
|
|
|
|
|
|
public final class Constants {
|
2012-07-19 08:20:54 +00:00
|
|
|
public static final class Color {
|
|
|
|
/**
|
|
|
|
* The alpha value for fully opaque.
|
|
|
|
*/
|
|
|
|
public final static int ALPHA_OPAQUE = 255;
|
|
|
|
}
|
|
|
|
|
2012-04-19 03:42:13 +00:00
|
|
|
public static final class ImeOption {
|
|
|
|
/**
|
|
|
|
* The private IME option used to indicate that no microphone should be shown for a given
|
|
|
|
* text field. For instance, this is specified by the search dialog when the dialog is
|
|
|
|
* already showing a voice search button.
|
|
|
|
*
|
|
|
|
* @deprecated Use {@link ImeOption#NO_MICROPHONE} with package name prefixed.
|
|
|
|
*/
|
|
|
|
@SuppressWarnings("dep-ann")
|
|
|
|
public static final String NO_MICROPHONE_COMPAT = "nm";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The private IME option used to indicate that no microphone should be shown for a given
|
|
|
|
* text field. For instance, this is specified by the search dialog when the dialog is
|
|
|
|
* already showing a voice search button.
|
|
|
|
*/
|
|
|
|
public static final String NO_MICROPHONE = "noMicrophoneKey";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The private IME option used to indicate that no settings key should be shown for a given
|
|
|
|
* text field.
|
|
|
|
*/
|
|
|
|
public static final String NO_SETTINGS_KEY = "noSettingsKey";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The private IME option used to indicate that the given text field needs ASCII code points
|
|
|
|
* input.
|
|
|
|
*
|
2012-09-10 03:56:10 +00:00
|
|
|
* @deprecated Use EditorInfo#IME_FLAG_FORCE_ASCII.
|
2012-04-19 03:42:13 +00:00
|
|
|
*/
|
|
|
|
@SuppressWarnings("dep-ann")
|
|
|
|
public static final String FORCE_ASCII = "forceAscii";
|
|
|
|
|
|
|
|
private ImeOption() {
|
|
|
|
// This utility class is not publicly instantiable.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static final class Subtype {
|
|
|
|
/**
|
|
|
|
* The subtype mode used to indicate that the subtype is a keyboard.
|
|
|
|
*/
|
|
|
|
public static final String KEYBOARD_MODE = "keyboard";
|
|
|
|
|
|
|
|
public static final class ExtraValue {
|
|
|
|
/**
|
|
|
|
* The subtype extra value used to indicate that the subtype keyboard layout is capable
|
|
|
|
* for typing ASCII characters.
|
|
|
|
*/
|
|
|
|
public static final String ASCII_CAPABLE = "AsciiCapable";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The subtype extra value used to indicate that the subtype require network connection
|
|
|
|
* to work.
|
|
|
|
*/
|
|
|
|
public static final String REQ_NETWORK_CONNECTIVITY = "requireNetworkConnectivity";
|
|
|
|
|
2012-05-06 16:47:14 +00:00
|
|
|
/**
|
|
|
|
* The subtype extra value used to indicate that the subtype display name contains "%s"
|
|
|
|
* for replacement mark and it should be replaced by this extra value.
|
|
|
|
* This extra value is supported on JellyBean and later.
|
|
|
|
*/
|
|
|
|
public static final String UNTRANSLATABLE_STRING_IN_SUBTYPE_NAME =
|
|
|
|
"UntranslatableReplacementStringInSubtypeName";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The subtype extra value used to indicate that the subtype keyboard layout set name.
|
|
|
|
* This extra value is private to LatinIME.
|
|
|
|
*/
|
|
|
|
public static final String KEYBOARD_LAYOUT_SET = "KeyboardLayoutSet";
|
|
|
|
|
2012-04-19 03:42:13 +00:00
|
|
|
/**
|
|
|
|
* The subtype extra value used to indicate that the subtype is additional subtype
|
|
|
|
* that the user defined. This extra value is private to LatinIME.
|
|
|
|
*/
|
|
|
|
public static final String IS_ADDITIONAL_SUBTYPE = "isAdditionalSubtype";
|
|
|
|
|
|
|
|
private ExtraValue() {
|
|
|
|
// This utility class is not publicly instantiable.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private Subtype() {
|
|
|
|
// This utility class is not publicly instantiable.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-01-06 02:10:27 +00:00
|
|
|
public static final class TextUtils {
|
2012-05-18 07:45:26 +00:00
|
|
|
/**
|
|
|
|
* Capitalization mode for {@link android.text.TextUtils#getCapsMode}: don't capitalize
|
|
|
|
* characters. This value may be used with
|
|
|
|
* {@link android.text.TextUtils#CAP_MODE_CHARACTERS},
|
|
|
|
* {@link android.text.TextUtils#CAP_MODE_WORDS}, and
|
|
|
|
* {@link android.text.TextUtils#CAP_MODE_SENTENCES}.
|
|
|
|
*/
|
|
|
|
public static final int CAP_MODE_OFF = 0;
|
|
|
|
|
|
|
|
private TextUtils() {
|
|
|
|
// This utility class is not publicly instantiable.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-01-06 02:10:27 +00:00
|
|
|
public static final class Dictionary {
|
2013-01-11 16:18:00 +00:00
|
|
|
// Must be identical to MAX_WORD_LENGTH in native/jni/src/defines.h
|
2012-09-07 07:49:16 +00:00
|
|
|
public static final int MAX_WORD_LENGTH = 48;
|
|
|
|
|
|
|
|
private Dictionary() {
|
|
|
|
// This utility class is no publicly instantiable.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-08-21 05:05:57 +00:00
|
|
|
public static final int NOT_A_CODE = -1;
|
|
|
|
|
|
|
|
public static final int NOT_A_COORDINATE = -1;
|
|
|
|
public static final int SUGGESTION_STRIP_COORDINATE = -2;
|
|
|
|
public static final int SPELL_CHECKER_COORDINATE = -3;
|
2012-12-26 06:38:53 +00:00
|
|
|
public static final int EXTERNAL_KEYBOARD_COORDINATE = -4;
|
2012-08-21 05:05:57 +00:00
|
|
|
|
2012-11-01 03:32:33 +00:00
|
|
|
public static boolean isValidCoordinate(final int coordinate) {
|
|
|
|
// Detect {@link NOT_A_COORDINATE}, {@link SUGGESTION_STRIP_COORDINATE},
|
|
|
|
// and {@link SPELL_CHECKER_COORDINATE}.
|
|
|
|
return coordinate >= 0;
|
|
|
|
}
|
|
|
|
|
2012-10-29 05:46:34 +00:00
|
|
|
/**
|
|
|
|
* Some common keys code. Must be positive.
|
|
|
|
*/
|
|
|
|
public static final int CODE_ENTER = '\n';
|
|
|
|
public static final int CODE_TAB = '\t';
|
|
|
|
public static final int CODE_SPACE = ' ';
|
|
|
|
public static final int CODE_PERIOD = '.';
|
|
|
|
public static final int CODE_DASH = '-';
|
|
|
|
public static final int CODE_SINGLE_QUOTE = '\'';
|
|
|
|
public static final int CODE_DOUBLE_QUOTE = '"';
|
|
|
|
public static final int CODE_QUESTION_MARK = '?';
|
|
|
|
public static final int CODE_EXCLAMATION_MARK = '!';
|
|
|
|
// TODO: Check how this should work for right-to-left languages. It seems to stand
|
|
|
|
// that for rtl languages, a closing parenthesis is a left parenthesis. Is this
|
|
|
|
// managed by the font? Or is it a different char?
|
|
|
|
public static final int CODE_CLOSING_PARENTHESIS = ')';
|
|
|
|
public static final int CODE_CLOSING_SQUARE_BRACKET = ']';
|
|
|
|
public static final int CODE_CLOSING_CURLY_BRACKET = '}';
|
|
|
|
public static final int CODE_CLOSING_ANGLE_BRACKET = '>';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Special keys code. Must be negative.
|
|
|
|
* These should be aligned with KeyboardCodesSet.ID_TO_NAME[],
|
|
|
|
* KeyboardCodesSet.DEFAULT[] and KeyboardCodesSet.RTL[]
|
|
|
|
*/
|
|
|
|
public static final int CODE_SHIFT = -1;
|
|
|
|
public static final int CODE_SWITCH_ALPHA_SYMBOL = -2;
|
|
|
|
public static final int CODE_OUTPUT_TEXT = -3;
|
|
|
|
public static final int CODE_DELETE = -4;
|
|
|
|
public static final int CODE_SETTINGS = -5;
|
|
|
|
public static final int CODE_SHORTCUT = -6;
|
|
|
|
public static final int CODE_ACTION_ENTER = -7;
|
|
|
|
public static final int CODE_ACTION_NEXT = -8;
|
|
|
|
public static final int CODE_ACTION_PREVIOUS = -9;
|
|
|
|
public static final int CODE_LANGUAGE_SWITCH = -10;
|
|
|
|
public static final int CODE_RESEARCH = -11;
|
2013-01-15 08:33:58 +00:00
|
|
|
public static final int CODE_SHIFT_ENTER = -12;
|
2012-10-29 05:46:34 +00:00
|
|
|
// Code value representing the code is not specified.
|
2013-01-15 08:33:58 +00:00
|
|
|
public static final int CODE_UNSPECIFIED = -13;
|
2012-10-29 05:46:34 +00:00
|
|
|
|
|
|
|
public static boolean isLetterCode(final int code) {
|
|
|
|
return code >= CODE_SPACE;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static String printableCode(final int code) {
|
|
|
|
switch (code) {
|
|
|
|
case CODE_SHIFT: return "shift";
|
|
|
|
case CODE_SWITCH_ALPHA_SYMBOL: return "symbol";
|
|
|
|
case CODE_OUTPUT_TEXT: return "text";
|
|
|
|
case CODE_DELETE: return "delete";
|
|
|
|
case CODE_SETTINGS: return "settings";
|
|
|
|
case CODE_SHORTCUT: return "shortcut";
|
|
|
|
case CODE_ACTION_ENTER: return "actionEnter";
|
|
|
|
case CODE_ACTION_NEXT: return "actionNext";
|
|
|
|
case CODE_ACTION_PREVIOUS: return "actionPrevious";
|
|
|
|
case CODE_LANGUAGE_SWITCH: return "languageSwitch";
|
|
|
|
case CODE_UNSPECIFIED: return "unspec";
|
|
|
|
case CODE_TAB: return "tab";
|
|
|
|
case CODE_ENTER: return "enter";
|
2012-08-29 00:05:27 +00:00
|
|
|
case CODE_RESEARCH: return "research";
|
2012-10-29 05:46:34 +00:00
|
|
|
default:
|
|
|
|
if (code < CODE_SPACE) return String.format("'\\u%02x'", code);
|
|
|
|
if (code < 0x100) return String.format("'%c'", code);
|
|
|
|
return String.format("'\\u%04x'", code);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-04-19 03:42:13 +00:00
|
|
|
private Constants() {
|
|
|
|
// This utility class is not publicly instantiable.
|
|
|
|
}
|
|
|
|
}
|