Refactor KeyboardTheme
This CL introduces two preference keys in addition to the existing one. - pref_keyboard_theme: The new preference key that is used only in the preference settings. - pref_keyboard_layout_20110916: The previous preference key that holds keyboard color scheme settings. This is superseded by the next key. - pref_keyboard_theme_20140509: The new preference key that holds keyboard theme settings. This value is forcibly reset to LMP theme on a LMP device. On a KitKat and previous device, the settings of the pref_keyboard_layout_20110916 is carried on into this preference. This CL must be checked in together with Id7b3ddd8aa. Change-Id: I2d55602d026e30b38d8f822d2124f5c5e4a9a812
This commit is contained in:
parent
6b74f516dc
commit
59c3ef1ff8
10 changed files with 269 additions and 45 deletions
|
@ -24,9 +24,6 @@
|
|||
at input history to suggest a hopefully helpful suggestions for the next word? -->
|
||||
<bool name="config_default_next_word_prediction">true</bool>
|
||||
|
||||
<!-- This configuration must be aligned with {@link KeyboardTheme#DEFAULT_THEME_ID}. -->
|
||||
<string name="config_default_keyboard_theme_id" translatable="false">2</string>
|
||||
|
||||
<integer name="config_delay_update_shift_state">100</integer>
|
||||
<integer name="config_double_space_period_timeout">1100</integer>
|
||||
|
||||
|
|
|
@ -47,17 +47,6 @@
|
|||
<string name="prefs_debug_mode">Debug Mode</string>
|
||||
<string name="prefs_force_non_distinct_multitouch">Force non-distinct multitouch</string>
|
||||
|
||||
<!-- For keyboard color scheme option dialog. -->
|
||||
<string-array name="keyboard_theme_names">
|
||||
<item>@string/keyboard_color_scheme_white</item>
|
||||
<item>@string/keyboard_color_scheme_blue</item>
|
||||
</string-array>
|
||||
<!-- An element must be a keyboard theme id of {@link KeyboardTheme#THEME_ID_*}. -->
|
||||
<string-array name="keyboard_theme_ids">
|
||||
<item>2</item>
|
||||
<item>0</item>
|
||||
</string-array>
|
||||
|
||||
<!-- Subtype locale display name exceptions.
|
||||
For each exception, there should be related string resources for display name that may have
|
||||
explicit keyboard layout. The string resource name must be "subtype_<locale>" or
|
||||
|
|
34
java/res/values/keyboard-themes.xml
Normal file
34
java/res/values/keyboard-themes.xml
Normal file
|
@ -0,0 +1,34 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!--
|
||||
/*
|
||||
**
|
||||
** Copyright 2014, 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.
|
||||
*/
|
||||
-->
|
||||
<resources xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||
<!-- For keyboard color scheme option dialog. -->
|
||||
<string-array name="keyboard_theme_names" translatable="false">
|
||||
<item>@string/keyboard_color_scheme_white</item>
|
||||
<item>@string/keyboard_color_scheme_blue</item>
|
||||
<!-- TODO: Make this item as translatable string resource. -->
|
||||
<item>Quantum</item>
|
||||
</string-array>
|
||||
<!-- An element must be a keyboard theme id of {@link KeyboardTheme#THEME_ID_*}. -->
|
||||
<string-array name="keyboard_theme_ids" translatable="false">
|
||||
<item>2</item>
|
||||
<item>0</item>
|
||||
<item>3</item>
|
||||
</string-array>
|
||||
</resources>
|
|
@ -158,12 +158,11 @@
|
|||
android:persistent="true"
|
||||
android:defaultValue="false" />
|
||||
<ListPreference
|
||||
android:key="pref_keyboard_layout_20110916"
|
||||
android:key="pref_keyboard_theme"
|
||||
android:title="@string/keyboard_color_scheme"
|
||||
android:persistent="true"
|
||||
android:entryValues="@array/keyboard_theme_ids"
|
||||
android:entries="@array/keyboard_theme_names"
|
||||
android:defaultValue="@string/config_default_keyboard_theme_id" />
|
||||
android:entries="@array/keyboard_theme_names" />
|
||||
<PreferenceScreen
|
||||
android:fragment="com.android.inputmethod.latin.settings.AdditionalSubtypeSettings"
|
||||
android:key="custom_input_styles"
|
||||
|
|
|
@ -64,7 +64,7 @@ public final class KeyboardSwitcher implements KeyboardState.SwitchActions {
|
|||
* what user actually typed. */
|
||||
private boolean mIsAutoCorrectionActive;
|
||||
|
||||
private KeyboardTheme mKeyboardTheme = KeyboardTheme.getDefaultKeyboardTheme();
|
||||
private KeyboardTheme mKeyboardTheme;
|
||||
private Context mThemeContext;
|
||||
|
||||
private static final KeyboardSwitcher sInstance = new KeyboardSwitcher();
|
||||
|
@ -101,7 +101,7 @@ public final class KeyboardSwitcher implements KeyboardState.SwitchActions {
|
|||
|
||||
private boolean updateKeyboardThemeAndContextThemeWrapper(final Context context,
|
||||
final KeyboardTheme keyboardTheme) {
|
||||
if (mThemeContext == null || mKeyboardTheme.mThemeId != keyboardTheme.mThemeId) {
|
||||
if (mThemeContext == null || !keyboardTheme.equals(mKeyboardTheme)) {
|
||||
mKeyboardTheme = keyboardTheme;
|
||||
mThemeContext = new ContextThemeWrapper(context, keyboardTheme.mStyleId);
|
||||
KeyboardLayoutSet.clearKeyboardCache();
|
||||
|
@ -342,7 +342,8 @@ public final class KeyboardSwitcher implements KeyboardState.SwitchActions {
|
|||
mKeyboardView.closing();
|
||||
}
|
||||
|
||||
updateKeyboardThemeAndContextThemeWrapper(mLatinIME, mKeyboardTheme);
|
||||
updateKeyboardThemeAndContextThemeWrapper(
|
||||
mLatinIME, KeyboardTheme.getKeyboardTheme(mPrefs));
|
||||
mCurrentInputView = (InputView)LayoutInflater.from(mThemeContext).inflate(
|
||||
R.layout.input_view, null);
|
||||
mMainKeyboardFrame = mCurrentInputView.findViewById(R.id.main_keyboard_frame);
|
||||
|
|
|
@ -17,34 +17,86 @@
|
|||
package com.android.inputmethod.keyboard;
|
||||
|
||||
import android.content.SharedPreferences;
|
||||
import android.os.Build;
|
||||
import android.os.Build.VERSION_CODES;
|
||||
import android.util.Log;
|
||||
|
||||
import com.android.inputmethod.latin.R;
|
||||
import com.android.inputmethod.latin.settings.Settings;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.Comparator;
|
||||
|
||||
public final class KeyboardTheme {
|
||||
private static final String TAG = KeyboardTheme.class.getSimpleName();
|
||||
|
||||
public static final int THEME_ID_ICS = 0;
|
||||
public static final int THEME_ID_KLP = 2;
|
||||
private static final int DEFAULT_THEME_ID = THEME_ID_KLP;
|
||||
static final String KITKAT_KEYBOARD_THEME_KEY = "pref_keyboard_layout_20110916";
|
||||
static final String KEYBOARD_THEME_KEY = "pref_keyboard_theme_20140509";
|
||||
|
||||
static final int THEME_ID_ICS = 0;
|
||||
static final int THEME_ID_KLP = 2;
|
||||
static final int THEME_ID_LMP = 3;
|
||||
static final int DEFAULT_THEME_ID = THEME_ID_KLP;
|
||||
|
||||
private static final KeyboardTheme[] KEYBOARD_THEMES = {
|
||||
new KeyboardTheme(THEME_ID_ICS, R.style.KeyboardTheme_ICS),
|
||||
new KeyboardTheme(THEME_ID_KLP, R.style.KeyboardTheme_KLP),
|
||||
new KeyboardTheme(THEME_ID_ICS, R.style.KeyboardTheme_ICS,
|
||||
VERSION_CODES.ICE_CREAM_SANDWICH),
|
||||
new KeyboardTheme(THEME_ID_KLP, R.style.KeyboardTheme_KLP,
|
||||
VERSION_CODES.KITKAT),
|
||||
// TODO: Update to LMP style.
|
||||
new KeyboardTheme(THEME_ID_LMP, R.style.KeyboardTheme_KLP,
|
||||
// TODO: Update this constant once the *next* version becomes available.
|
||||
VERSION_CODES.CUR_DEVELOPMENT),
|
||||
};
|
||||
static {
|
||||
// Sort {@link #KEYBOARD_THEME} by descending order of {@link #mMinApiVersion}.
|
||||
Arrays.sort(KEYBOARD_THEMES, new Comparator<KeyboardTheme>() {
|
||||
@Override
|
||||
public int compare(final KeyboardTheme lhs, final KeyboardTheme rhs) {
|
||||
if (lhs.mMinApiVersion > rhs.mMinApiVersion) return -1;
|
||||
if (lhs.mMinApiVersion < rhs.mMinApiVersion) return 1;
|
||||
return 0;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public final int mThemeId;
|
||||
public final int mStyleId;
|
||||
final int mMinApiVersion;
|
||||
|
||||
// Note: The themeId should be aligned with "themeId" attribute of Keyboard style
|
||||
// in values/style.xml.
|
||||
public KeyboardTheme(final int themeId, final int styleId) {
|
||||
// in values/themes-<style>.xml.
|
||||
private KeyboardTheme(final int themeId, final int styleId, final int minApiVersion) {
|
||||
mThemeId = themeId;
|
||||
mStyleId = styleId;
|
||||
mMinApiVersion = minApiVersion;
|
||||
}
|
||||
|
||||
private static KeyboardTheme searchKeyboardTheme(final int themeId) {
|
||||
@Override
|
||||
public boolean equals(final Object o) {
|
||||
if (o == this) return true;
|
||||
return (o instanceof KeyboardTheme) && ((KeyboardTheme)o).mThemeId == mThemeId;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashCode() {
|
||||
return mThemeId;
|
||||
}
|
||||
|
||||
// TODO: This method should be removed when {@link LatinImeLogger} is removed.
|
||||
public int getCompatibleThemeIdForLogging() {
|
||||
switch (mThemeId) {
|
||||
case THEME_ID_ICS:
|
||||
return 5;
|
||||
case THEME_ID_KLP:
|
||||
return 9;
|
||||
case THEME_ID_LMP:
|
||||
return 10;
|
||||
default: // Invalid theme
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
private static KeyboardTheme searchKeyboardThemeById(final int themeId) {
|
||||
// TODO: This search algorithm isn't optimal if there are many themes.
|
||||
for (final KeyboardTheme theme : KEYBOARD_THEMES) {
|
||||
if (theme.mThemeId == themeId) {
|
||||
|
@ -54,18 +106,57 @@ public final class KeyboardTheme {
|
|||
return null;
|
||||
}
|
||||
|
||||
public static KeyboardTheme getDefaultKeyboardTheme() {
|
||||
return searchKeyboardTheme(DEFAULT_THEME_ID);
|
||||
private static int getSdkVersion() {
|
||||
final int sdkVersion = Build.VERSION.SDK_INT;
|
||||
// TODO: Consider to remove this check once the *next* version becomes available.
|
||||
if (sdkVersion == VERSION_CODES.KITKAT && Build.VERSION.CODENAME.startsWith("L")) {
|
||||
return VERSION_CODES.CUR_DEVELOPMENT;
|
||||
}
|
||||
return sdkVersion;
|
||||
}
|
||||
|
||||
static KeyboardTheme getDefaultKeyboardTheme(final SharedPreferences prefs,
|
||||
final int sdkVersion) {
|
||||
final String obsoleteIdString = prefs.getString(KITKAT_KEYBOARD_THEME_KEY, null);
|
||||
if (obsoleteIdString != null) {
|
||||
// Remove old preference.
|
||||
prefs.edit().remove(KITKAT_KEYBOARD_THEME_KEY).apply();
|
||||
if (sdkVersion <= VERSION_CODES.KITKAT) {
|
||||
try {
|
||||
final int themeId = Integer.parseInt(obsoleteIdString);
|
||||
final KeyboardTheme theme = searchKeyboardThemeById(themeId);
|
||||
if (theme != null) {
|
||||
return theme;
|
||||
}
|
||||
Log.w(TAG, "Unknown keyboard theme in preference: " + obsoleteIdString);
|
||||
} catch (final NumberFormatException e) {
|
||||
Log.w(TAG, "Illegal keyboard theme in preference: " + obsoleteIdString);
|
||||
}
|
||||
}
|
||||
}
|
||||
// TODO: This search algorithm isn't optimal if there are many themes.
|
||||
for (final KeyboardTheme theme : KEYBOARD_THEMES) {
|
||||
if (sdkVersion >= theme.mMinApiVersion) {
|
||||
return theme;
|
||||
}
|
||||
}
|
||||
return searchKeyboardThemeById(DEFAULT_THEME_ID);
|
||||
}
|
||||
|
||||
public static void saveKeyboardThemeId(final String themeIdString,
|
||||
final SharedPreferences prefs) {
|
||||
prefs.edit().putString(KEYBOARD_THEME_KEY, themeIdString).apply();
|
||||
}
|
||||
|
||||
public static KeyboardTheme getKeyboardTheme(final SharedPreferences prefs) {
|
||||
final String themeIdString = prefs.getString(Settings.PREF_KEYBOARD_LAYOUT, null);
|
||||
final int sdkVersion = getSdkVersion();
|
||||
final String themeIdString = prefs.getString(KEYBOARD_THEME_KEY, null);
|
||||
if (themeIdString == null) {
|
||||
return getDefaultKeyboardTheme();
|
||||
return getDefaultKeyboardTheme(prefs, sdkVersion);
|
||||
}
|
||||
try {
|
||||
final int themeId = Integer.parseInt(themeIdString);
|
||||
final KeyboardTheme theme = searchKeyboardTheme(themeId);
|
||||
final KeyboardTheme theme = searchKeyboardThemeById(themeId);
|
||||
if (theme != null) {
|
||||
return theme;
|
||||
}
|
||||
|
@ -73,9 +164,8 @@ public final class KeyboardTheme {
|
|||
} catch (final NumberFormatException e) {
|
||||
Log.w(TAG, "Illegal keyboard theme in preference: " + themeIdString);
|
||||
}
|
||||
// Reset preference to default value.
|
||||
final String defaultThemeIdString = Integer.toString(DEFAULT_THEME_ID);
|
||||
prefs.edit().putString(Settings.PREF_KEYBOARD_LAYOUT, defaultThemeIdString).apply();
|
||||
return getDefaultKeyboardTheme();
|
||||
// Remove preference.
|
||||
prefs.edit().remove(KEYBOARD_THEME_KEY).apply();
|
||||
return getDefaultKeyboardTheme(prefs, sdkVersion);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -64,7 +64,7 @@ public final class Settings implements SharedPreferences.OnSharedPreferenceChang
|
|||
"pref_show_language_switch_key";
|
||||
public static final String PREF_INCLUDE_OTHER_IMES_IN_LANGUAGE_SWITCH_LIST =
|
||||
"pref_include_other_imes_in_language_switch_list";
|
||||
public static final String PREF_KEYBOARD_LAYOUT = "pref_keyboard_layout_20110916";
|
||||
public static final String PREF_KEYBOARD_THEME = "pref_keyboard_theme";
|
||||
public static final String PREF_CUSTOM_INPUT_STYLES = "custom_input_styles";
|
||||
// TODO: consolidate key preview dismiss delay with the key preview animation parameters.
|
||||
public static final String PREF_KEY_PREVIEW_POPUP_DISMISS_DELAY =
|
||||
|
|
|
@ -37,6 +37,7 @@ import android.util.Log;
|
|||
import android.view.inputmethod.InputMethodSubtype;
|
||||
|
||||
import com.android.inputmethod.dictionarypack.DictionarySettingsActivity;
|
||||
import com.android.inputmethod.keyboard.KeyboardTheme;
|
||||
import com.android.inputmethod.latin.AudioAndHapticFeedbackManager;
|
||||
import com.android.inputmethod.latin.R;
|
||||
import com.android.inputmethod.latin.SubtypeSwitcher;
|
||||
|
@ -253,10 +254,30 @@ public final class SettingsFragment extends InputMethodSettingsFragment
|
|||
}
|
||||
updateListPreferenceSummaryToCurrentValue(Settings.PREF_SHOW_SUGGESTIONS_SETTING);
|
||||
updateListPreferenceSummaryToCurrentValue(Settings.PREF_KEY_PREVIEW_POPUP_DISMISS_DELAY);
|
||||
updateListPreferenceSummaryToCurrentValue(Settings.PREF_KEYBOARD_LAYOUT);
|
||||
final ListPreference keyboardThemePref = (ListPreference)findPreference(
|
||||
Settings.PREF_KEYBOARD_THEME);
|
||||
if (keyboardThemePref != null) {
|
||||
final KeyboardTheme keyboardTheme = KeyboardTheme.getKeyboardTheme(prefs);
|
||||
final String value = Integer.toString(keyboardTheme.mThemeId);
|
||||
final CharSequence entries[] = keyboardThemePref.getEntries();
|
||||
final int entryIndex = keyboardThemePref.findIndexOfValue(value);
|
||||
keyboardThemePref.setSummary(entryIndex < 0 ? null : entries[entryIndex]);
|
||||
keyboardThemePref.setValue(value);
|
||||
}
|
||||
updateCustomInputStylesSummary(prefs, res);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onPause() {
|
||||
super.onPause();
|
||||
final SharedPreferences prefs = getPreferenceManager().getSharedPreferences();
|
||||
final ListPreference keyboardThemePref = (ListPreference)findPreference(
|
||||
Settings.PREF_KEYBOARD_THEME);
|
||||
if (keyboardThemePref != null) {
|
||||
KeyboardTheme.saveKeyboardThemeId(keyboardThemePref.getValue(), prefs);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onDestroy() {
|
||||
getPreferenceManager().getSharedPreferences().unregisterOnSharedPreferenceChangeListener(
|
||||
|
@ -287,7 +308,7 @@ public final class SettingsFragment extends InputMethodSettingsFragment
|
|||
ensureConsistencyOfAutoCorrectionSettings();
|
||||
updateListPreferenceSummaryToCurrentValue(Settings.PREF_SHOW_SUGGESTIONS_SETTING);
|
||||
updateListPreferenceSummaryToCurrentValue(Settings.PREF_KEY_PREVIEW_POPUP_DISMISS_DELAY);
|
||||
updateListPreferenceSummaryToCurrentValue(Settings.PREF_KEYBOARD_LAYOUT);
|
||||
updateListPreferenceSummaryToCurrentValue(Settings.PREF_KEYBOARD_THEME);
|
||||
refreshEnablingsOfKeypressSoundAndVibrationSettings(prefs, getResources());
|
||||
}
|
||||
|
||||
|
|
|
@ -18,6 +18,7 @@ package com.android.inputmethod.keyboard;
|
|||
|
||||
import android.content.Context;
|
||||
import android.content.res.Resources;
|
||||
import android.preference.PreferenceManager;
|
||||
import android.test.AndroidTestCase;
|
||||
import android.test.suitebuilder.annotation.SmallTest;
|
||||
import android.view.ContextThemeWrapper;
|
||||
|
@ -40,9 +41,6 @@ import java.util.Locale;
|
|||
|
||||
@SmallTest
|
||||
public class KeyboardLayoutSetTestsBase extends AndroidTestCase {
|
||||
private static final KeyboardTheme DEFAULT_KEYBOARD_THEME =
|
||||
KeyboardTheme.getDefaultKeyboardTheme();
|
||||
|
||||
// All input method subtypes of LatinIME.
|
||||
private final ArrayList<InputMethodSubtype> mAllSubtypesList = CollectionUtils.newArrayList();
|
||||
private final ArrayList<InputMethodSubtype> mAsciiCapableSubtypesList =
|
||||
|
@ -58,7 +56,9 @@ public class KeyboardLayoutSetTestsBase extends AndroidTestCase {
|
|||
super.setUp();
|
||||
mScreenMetrics = mContext.getResources().getInteger(R.integer.config_screen_metrics);
|
||||
|
||||
mThemeContext = new ContextThemeWrapper(mContext, DEFAULT_KEYBOARD_THEME.mStyleId);
|
||||
final KeyboardTheme keyboardTheme = KeyboardTheme.getKeyboardTheme(
|
||||
PreferenceManager.getDefaultSharedPreferences(mContext));
|
||||
mThemeContext = new ContextThemeWrapper(mContext, keyboardTheme.mStyleId);
|
||||
RichInputMethodManager.init(mThemeContext);
|
||||
final RichInputMethodManager richImm = RichInputMethodManager.getInstance();
|
||||
|
||||
|
|
|
@ -0,0 +1,93 @@
|
|||
/*
|
||||
* Copyright (C) 2014 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;
|
||||
|
||||
import android.content.SharedPreferences;
|
||||
import android.os.Build.VERSION_CODES;
|
||||
import android.preference.PreferenceManager;
|
||||
import android.test.AndroidTestCase;
|
||||
import android.test.suitebuilder.annotation.SmallTest;
|
||||
|
||||
@SmallTest
|
||||
public class KeyboardThemeTests extends AndroidTestCase {
|
||||
private SharedPreferences mPrefs;
|
||||
|
||||
private static final int THEME_ID_NULL = -1;
|
||||
private static final int THEME_ID_ICS = KeyboardTheme.THEME_ID_ICS;
|
||||
private static final int THEME_ID_KLP = KeyboardTheme.THEME_ID_KLP;
|
||||
private static final int THEME_ID_LMP = KeyboardTheme.THEME_ID_LMP;
|
||||
|
||||
@Override
|
||||
protected void setUp() throws Exception {
|
||||
super.setUp();
|
||||
mPrefs = PreferenceManager.getDefaultSharedPreferences(getContext());
|
||||
}
|
||||
|
||||
private void assertDefaultKeyboardTheme(final int sdkVersion, final int oldThemeId,
|
||||
final int expectedThemeId) {
|
||||
if (oldThemeId == THEME_ID_NULL) {
|
||||
mPrefs.edit().remove(KeyboardTheme.KITKAT_KEYBOARD_THEME_KEY).apply();
|
||||
} else {
|
||||
final String themeIdString = Integer.toString(oldThemeId);
|
||||
mPrefs.edit().putString(KeyboardTheme.KITKAT_KEYBOARD_THEME_KEY, themeIdString).apply();
|
||||
}
|
||||
final KeyboardTheme defaultTheme =
|
||||
KeyboardTheme.getDefaultKeyboardTheme(mPrefs, sdkVersion);
|
||||
assertNotNull(defaultTheme);
|
||||
assertEquals(expectedThemeId, defaultTheme.mThemeId);
|
||||
assertFalse(mPrefs.contains(KeyboardTheme.KITKAT_KEYBOARD_THEME_KEY));
|
||||
}
|
||||
|
||||
private void assertDefaultKeyboardThemeICS(final int sdkVersion) {
|
||||
assertDefaultKeyboardTheme(sdkVersion, THEME_ID_NULL, THEME_ID_ICS);
|
||||
assertDefaultKeyboardTheme(sdkVersion, THEME_ID_ICS, THEME_ID_ICS);
|
||||
assertDefaultKeyboardTheme(sdkVersion, THEME_ID_KLP, THEME_ID_KLP);
|
||||
}
|
||||
|
||||
private void assertDefaultKeyboardThemeKLP(final int sdkVersion) {
|
||||
assertDefaultKeyboardTheme(sdkVersion, THEME_ID_NULL, THEME_ID_KLP);
|
||||
assertDefaultKeyboardTheme(sdkVersion, THEME_ID_ICS, THEME_ID_ICS);
|
||||
assertDefaultKeyboardTheme(sdkVersion, THEME_ID_KLP, THEME_ID_KLP);
|
||||
}
|
||||
|
||||
private void assertDefaultKeyboardThemeLMP(final int sdkVersion) {
|
||||
// Forced to switch to LMP theme.
|
||||
assertDefaultKeyboardTheme(sdkVersion, THEME_ID_NULL, THEME_ID_LMP);
|
||||
assertDefaultKeyboardTheme(sdkVersion, THEME_ID_ICS, THEME_ID_LMP);
|
||||
assertDefaultKeyboardTheme(sdkVersion, THEME_ID_KLP, THEME_ID_LMP);
|
||||
}
|
||||
|
||||
public void testDefaultKeyboardThemeICS() {
|
||||
assertDefaultKeyboardThemeICS(VERSION_CODES.ICE_CREAM_SANDWICH);
|
||||
assertDefaultKeyboardThemeICS(VERSION_CODES.ICE_CREAM_SANDWICH_MR1);
|
||||
}
|
||||
|
||||
public void testDefaultKeyboardThemeJB() {
|
||||
assertDefaultKeyboardThemeICS(VERSION_CODES.JELLY_BEAN);
|
||||
assertDefaultKeyboardThemeICS(VERSION_CODES.JELLY_BEAN_MR1);
|
||||
assertDefaultKeyboardThemeICS(VERSION_CODES.JELLY_BEAN_MR2);
|
||||
}
|
||||
|
||||
public void testDefaultKeyboardThemeKLP() {
|
||||
assertDefaultKeyboardThemeKLP(VERSION_CODES.KITKAT);
|
||||
}
|
||||
|
||||
public void testDefaultKeyboardThemeLMP() {
|
||||
// TODO: Update this constant once the *next* version becomes available.
|
||||
assertDefaultKeyboardThemeLMP(VERSION_CODES.CUR_DEVELOPMENT);
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue