Start showing the split keyboard layout
Change [3/3] Added tests for Qwerty/en-US/split Parse the switch-case statement from KeyboardBuilder to use the right layout. Bug: 4968173 Change-Id: If4d6d71d5900525290268d8affa55dccf1ebd4f2
This commit is contained in:
parent
fc12c0a7fd
commit
081c2d386d
13 changed files with 131 additions and 23 deletions
|
@ -24,7 +24,7 @@
|
||||||
latin:elementName="alphabet"
|
latin:elementName="alphabet"
|
||||||
latin:elementKeyboard="@xml/kbd_qwerty"
|
latin:elementKeyboard="@xml/kbd_qwerty"
|
||||||
latin:enableProximityCharsCorrection="true"
|
latin:enableProximityCharsCorrection="true"
|
||||||
latin:supportsSplitLayout="false" />
|
latin:supportsSplitLayout="true" />
|
||||||
<Element
|
<Element
|
||||||
latin:elementName="symbols"
|
latin:elementName="symbols"
|
||||||
latin:elementKeyboard="@xml/kbd_symbols" />
|
latin:elementKeyboard="@xml/kbd_symbols" />
|
||||||
|
|
|
@ -77,8 +77,7 @@ public final class KeyboardId {
|
||||||
|
|
||||||
private final int mHashCode;
|
private final int mHashCode;
|
||||||
|
|
||||||
public KeyboardId(final int elementId, final KeyboardLayoutSet.Params params,
|
public KeyboardId(final int elementId, final KeyboardLayoutSet.Params params) {
|
||||||
boolean isSplitLayout) {
|
|
||||||
mSubtype = params.mSubtype;
|
mSubtype = params.mSubtype;
|
||||||
mLocale = SubtypeLocaleUtils.getSubtypeLocale(mSubtype);
|
mLocale = SubtypeLocaleUtils.getSubtypeLocale(mSubtype);
|
||||||
mWidth = params.mKeyboardWidth;
|
mWidth = params.mKeyboardWidth;
|
||||||
|
@ -91,7 +90,7 @@ public final class KeyboardId {
|
||||||
mCustomActionLabel = (mEditorInfo.actionLabel != null)
|
mCustomActionLabel = (mEditorInfo.actionLabel != null)
|
||||||
? mEditorInfo.actionLabel.toString() : null;
|
? mEditorInfo.actionLabel.toString() : null;
|
||||||
mHasShortcutKey = params.mVoiceInputKeyEnabled;
|
mHasShortcutKey = params.mVoiceInputKeyEnabled;
|
||||||
mIsSplitLayout = isSplitLayout;
|
mIsSplitLayout = params.mIsSplitLayoutEnabled;
|
||||||
|
|
||||||
mHashCode = computeHashCode(this);
|
mHashCode = computeHashCode(this);
|
||||||
}
|
}
|
||||||
|
|
|
@ -115,6 +115,12 @@ public final class KeyboardLayoutSet {
|
||||||
int mKeyboardWidth;
|
int mKeyboardWidth;
|
||||||
int mKeyboardHeight;
|
int mKeyboardHeight;
|
||||||
int mScriptId = ScriptUtils.SCRIPT_LATIN;
|
int mScriptId = ScriptUtils.SCRIPT_LATIN;
|
||||||
|
// Indicates if the user has enabled the split-layout preference
|
||||||
|
// and the required ProductionFlags are enabled.
|
||||||
|
boolean mIsSplitLayoutEnabledByUser;
|
||||||
|
// Indicates if split layout is actually enabled, taking into account
|
||||||
|
// whether the user has enabled it, and the keyboard layout supports it.
|
||||||
|
boolean mIsSplitLayoutEnabled;
|
||||||
// Sparse array of KeyboardLayoutSet element parameters indexed by element's id.
|
// Sparse array of KeyboardLayoutSet element parameters indexed by element's id.
|
||||||
final SparseArray<ElementParams> mKeyboardLayoutSetElementIdToParamsMap =
|
final SparseArray<ElementParams> mKeyboardLayoutSetElementIdToParamsMap =
|
||||||
new SparseArray<>();
|
new SparseArray<>();
|
||||||
|
@ -170,9 +176,9 @@ public final class KeyboardLayoutSet {
|
||||||
// specified as an elementKeyboard attribute in the file.
|
// specified as an elementKeyboard attribute in the file.
|
||||||
// The KeyboardId is an internal key for a Keyboard object.
|
// The KeyboardId is an internal key for a Keyboard object.
|
||||||
|
|
||||||
// TODO: AND mSupportsSplitLayout with the user preference that forces a split.
|
mParams.mIsSplitLayoutEnabled = mParams.mIsSplitLayoutEnabledByUser
|
||||||
final KeyboardId id = new KeyboardId(keyboardLayoutSetElementId, mParams,
|
&& elementParams.mSupportsSplitLayout;
|
||||||
elementParams.mSupportsSplitLayout);
|
final KeyboardId id = new KeyboardId(keyboardLayoutSetElementId, mParams);
|
||||||
try {
|
try {
|
||||||
return getKeyboard(elementParams, id);
|
return getKeyboard(elementParams, id);
|
||||||
} catch (final RuntimeException e) {
|
} catch (final RuntimeException e) {
|
||||||
|
@ -290,12 +296,19 @@ public final class KeyboardLayoutSet {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void disableTouchPositionCorrectionData() {
|
public Builder disableTouchPositionCorrectionData() {
|
||||||
mParams.mDisableTouchPositionCorrectionDataForTest = true;
|
mParams.mDisableTouchPositionCorrectionDataForTest = true;
|
||||||
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setScriptId(final int scriptId) {
|
public Builder setScriptId(final int scriptId) {
|
||||||
mParams.mScriptId = scriptId;
|
mParams.mScriptId = scriptId;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder setSplitLayoutEnabledByUser(final boolean enabled) {
|
||||||
|
mParams.mIsSplitLayoutEnabledByUser = enabled;
|
||||||
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public KeyboardLayoutSet build() {
|
public KeyboardLayoutSet build() {
|
||||||
|
|
|
@ -36,6 +36,7 @@ import com.android.inputmethod.latin.R;
|
||||||
import com.android.inputmethod.latin.RichInputMethodManager;
|
import com.android.inputmethod.latin.RichInputMethodManager;
|
||||||
import com.android.inputmethod.latin.SubtypeSwitcher;
|
import com.android.inputmethod.latin.SubtypeSwitcher;
|
||||||
import com.android.inputmethod.latin.WordComposer;
|
import com.android.inputmethod.latin.WordComposer;
|
||||||
|
import com.android.inputmethod.latin.define.ProductionFlags;
|
||||||
import com.android.inputmethod.latin.settings.Settings;
|
import com.android.inputmethod.latin.settings.Settings;
|
||||||
import com.android.inputmethod.latin.settings.SettingsValues;
|
import com.android.inputmethod.latin.settings.SettingsValues;
|
||||||
import com.android.inputmethod.latin.utils.ResourceUtils;
|
import com.android.inputmethod.latin.utils.ResourceUtils;
|
||||||
|
@ -114,6 +115,8 @@ public final class KeyboardSwitcher implements KeyboardState.SwitchActions {
|
||||||
builder.setSubtype(mSubtypeSwitcher.getCurrentSubtype());
|
builder.setSubtype(mSubtypeSwitcher.getCurrentSubtype());
|
||||||
builder.setVoiceInputKeyEnabled(settingsValues.mShowsVoiceInputKey);
|
builder.setVoiceInputKeyEnabled(settingsValues.mShowsVoiceInputKey);
|
||||||
builder.setLanguageSwitchKeyEnabled(mLatinIME.shouldShowLanguageSwitchKey());
|
builder.setLanguageSwitchKeyEnabled(mLatinIME.shouldShowLanguageSwitchKey());
|
||||||
|
builder.setSplitLayoutEnabledByUser(ProductionFlags.IS_SPLIT_KEYBOARD_SUPPORTED
|
||||||
|
&& settingsValues.mIsSplitKeyboardEnabled);
|
||||||
mKeyboardLayoutSet = builder.build();
|
mKeyboardLayoutSet = builder.build();
|
||||||
try {
|
try {
|
||||||
mState.onLoadKeyboard(currentAutoCapsState, currentRecapitalizeState);
|
mState.onLoadKeyboard(currentAutoCapsState, currentRecapitalizeState);
|
||||||
|
|
|
@ -674,15 +674,18 @@ public class KeyboardBuilder<KP extends KeyboardParams> {
|
||||||
R.styleable.Keyboard_Case_languageCode, id.mLocale.getLanguage());
|
R.styleable.Keyboard_Case_languageCode, id.mLocale.getLanguage());
|
||||||
final boolean countryCodeMatched = matchString(caseAttr,
|
final boolean countryCodeMatched = matchString(caseAttr,
|
||||||
R.styleable.Keyboard_Case_countryCode, id.mLocale.getCountry());
|
R.styleable.Keyboard_Case_countryCode, id.mLocale.getCountry());
|
||||||
|
final boolean splitLayoutMatched = matchBoolean(caseAttr,
|
||||||
|
R.styleable.Keyboard_Case_isSplitLayout, id.mIsSplitLayout);
|
||||||
final boolean selected = keyboardLayoutSetMatched && keyboardLayoutSetElementMatched
|
final boolean selected = keyboardLayoutSetMatched && keyboardLayoutSetElementMatched
|
||||||
&& keyboardThemeMacthed && modeMatched && navigateNextMatched
|
&& keyboardThemeMacthed && modeMatched && navigateNextMatched
|
||||||
&& navigatePreviousMatched && passwordInputMatched && clobberSettingsKeyMatched
|
&& navigatePreviousMatched && passwordInputMatched && clobberSettingsKeyMatched
|
||||||
&& hasShortcutKeyMatched && languageSwitchKeyEnabledMatched
|
&& hasShortcutKeyMatched && languageSwitchKeyEnabledMatched
|
||||||
&& isMultiLineMatched && imeActionMatched && isIconDefinedMatched
|
&& isMultiLineMatched && imeActionMatched && isIconDefinedMatched
|
||||||
&& localeCodeMatched && languageCodeMatched && countryCodeMatched;
|
&& localeCodeMatched && languageCodeMatched && countryCodeMatched
|
||||||
|
&& splitLayoutMatched;
|
||||||
|
|
||||||
if (DEBUG) {
|
if (DEBUG) {
|
||||||
startTag("<%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s>%s", TAG_CASE,
|
startTag("<%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s>%s", TAG_CASE,
|
||||||
textAttr(caseAttr.getString(
|
textAttr(caseAttr.getString(
|
||||||
R.styleable.Keyboard_Case_keyboardLayoutSet), "keyboardLayoutSet"),
|
R.styleable.Keyboard_Case_keyboardLayoutSet), "keyboardLayoutSet"),
|
||||||
textAttr(caseAttr.getString(
|
textAttr(caseAttr.getString(
|
||||||
|
@ -707,6 +710,8 @@ public class KeyboardBuilder<KP extends KeyboardParams> {
|
||||||
"languageSwitchKeyEnabled"),
|
"languageSwitchKeyEnabled"),
|
||||||
booleanAttr(caseAttr, R.styleable.Keyboard_Case_isMultiLine,
|
booleanAttr(caseAttr, R.styleable.Keyboard_Case_isMultiLine,
|
||||||
"isMultiLine"),
|
"isMultiLine"),
|
||||||
|
booleanAttr(caseAttr, R.styleable.Keyboard_Case_isSplitLayout,
|
||||||
|
"splitLayout"),
|
||||||
textAttr(caseAttr.getString(R.styleable.Keyboard_Case_isIconDefined),
|
textAttr(caseAttr.getString(R.styleable.Keyboard_Case_isIconDefined),
|
||||||
"isIconDefined"),
|
"isIconDefined"),
|
||||||
textAttr(caseAttr.getString(R.styleable.Keyboard_Case_localeCode),
|
textAttr(caseAttr.getString(R.styleable.Keyboard_Case_localeCode),
|
||||||
|
|
|
@ -117,12 +117,12 @@ public abstract class KeyboardLayoutSetTestsBase extends AndroidTestCase {
|
||||||
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
||||||
final EditorInfo editorInfo) {
|
final EditorInfo editorInfo) {
|
||||||
return createKeyboardLayoutSet(subtype, editorInfo, false /* voiceInputKeyEnabled */,
|
return createKeyboardLayoutSet(subtype, editorInfo, false /* voiceInputKeyEnabled */,
|
||||||
false /* languageSwitchKeyEnabled */);
|
false /* languageSwitchKeyEnabled */, false /* splitLayoutEnabled */);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
||||||
final EditorInfo editorInfo, final boolean voiceInputKeyEnabled,
|
final EditorInfo editorInfo, final boolean voiceInputKeyEnabled,
|
||||||
final boolean languageSwitchKeyEnabled) {
|
final boolean languageSwitchKeyEnabled, final boolean splitLayoutEnabled) {
|
||||||
final Context context = getContext();
|
final Context context = getContext();
|
||||||
final Resources res = context.getResources();
|
final Resources res = context.getResources();
|
||||||
final int keyboardWidth = ResourceUtils.getDefaultKeyboardWidth(res);
|
final int keyboardWidth = ResourceUtils.getDefaultKeyboardWidth(res);
|
||||||
|
@ -131,7 +131,8 @@ public abstract class KeyboardLayoutSetTestsBase extends AndroidTestCase {
|
||||||
builder.setKeyboardGeometry(keyboardWidth, keyboardHeight)
|
builder.setKeyboardGeometry(keyboardWidth, keyboardHeight)
|
||||||
.setSubtype(new RichInputMethodSubtype(subtype))
|
.setSubtype(new RichInputMethodSubtype(subtype))
|
||||||
.setVoiceInputKeyEnabled(voiceInputKeyEnabled)
|
.setVoiceInputKeyEnabled(voiceInputKeyEnabled)
|
||||||
.setLanguageSwitchKeyEnabled(languageSwitchKeyEnabled);
|
.setLanguageSwitchKeyEnabled(languageSwitchKeyEnabled)
|
||||||
|
.setSplitLayoutEnabledByUser(splitLayoutEnabled);
|
||||||
return builder.build();
|
return builder.build();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,35 @@
|
||||||
|
/*
|
||||||
|
* 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.layout.tests;
|
||||||
|
|
||||||
|
import com.android.inputmethod.keyboard.layout.LayoutBase;
|
||||||
|
import com.android.inputmethod.keyboard.layout.expected.ExpectedKey;
|
||||||
|
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
public class EnglishSplitCustomizer extends EnglishCustomizer {
|
||||||
|
|
||||||
|
EnglishSplitCustomizer(Locale locale) {
|
||||||
|
super(locale);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ExpectedKey[] getSpaceKeys(final boolean isPhone) {
|
||||||
|
return LayoutBase.joinKeys(
|
||||||
|
LayoutBase.LANGUAGE_SWITCH_KEY, LayoutBase.SPACE_KEY, LayoutBase.SPACE_KEY);
|
||||||
|
}
|
||||||
|
}
|
|
@ -54,7 +54,8 @@ abstract class LayoutTestsBase extends KeyboardLayoutSetTestsBase {
|
||||||
+ (isPhone() ? "phone" : "tablet");
|
+ (isPhone() ? "phone" : "tablet");
|
||||||
// TODO: Test with language switch key enabled and disabled.
|
// TODO: Test with language switch key enabled and disabled.
|
||||||
mKeyboardLayoutSet = createKeyboardLayoutSet(mSubtype, null /* editorInfo */,
|
mKeyboardLayoutSet = createKeyboardLayoutSet(mSubtype, null /* editorInfo */,
|
||||||
true /* voiceInputKeyEnabled */, true /* languageSwitchKeyEnabled */);
|
true /* voiceInputKeyEnabled */, true /* languageSwitchKeyEnabled */,
|
||||||
|
false /* splitLayoutEnabled */);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -44,12 +44,13 @@ public class TestsDvorakEmail extends LayoutTestsBase {
|
||||||
@Override
|
@Override
|
||||||
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
||||||
final EditorInfo editorInfo, final boolean voiceInputKeyEnabled,
|
final EditorInfo editorInfo, final boolean voiceInputKeyEnabled,
|
||||||
final boolean languageSwitchKeyEnabled) {
|
final boolean languageSwitchKeyEnabled, final boolean splitLayoutEnabled) {
|
||||||
final EditorInfo emailField = new EditorInfo();
|
final EditorInfo emailField = new EditorInfo();
|
||||||
emailField.inputType =
|
emailField.inputType =
|
||||||
InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_EMAIL_ADDRESS;
|
InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_EMAIL_ADDRESS;
|
||||||
return super.createKeyboardLayoutSet(
|
return super.createKeyboardLayoutSet(
|
||||||
subtype, emailField, voiceInputKeyEnabled, languageSwitchKeyEnabled);
|
subtype, emailField, voiceInputKeyEnabled, languageSwitchKeyEnabled,
|
||||||
|
splitLayoutEnabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class DvorakEmailCustomizer extends EnglishDvorakCustomizer {
|
private static class DvorakEmailCustomizer extends EnglishDvorakCustomizer {
|
||||||
|
|
|
@ -44,12 +44,13 @@ public class TestsDvorakUrl extends LayoutTestsBase {
|
||||||
@Override
|
@Override
|
||||||
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
||||||
final EditorInfo editorInfo, final boolean voiceInputKeyEnabled,
|
final EditorInfo editorInfo, final boolean voiceInputKeyEnabled,
|
||||||
final boolean languageSwitchKeyEnabled) {
|
final boolean languageSwitchKeyEnabled, final boolean splitLayoutEnabled) {
|
||||||
final EditorInfo emailField = new EditorInfo();
|
final EditorInfo emailField = new EditorInfo();
|
||||||
emailField.inputType =
|
emailField.inputType =
|
||||||
InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_URI;
|
InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_URI;
|
||||||
return super.createKeyboardLayoutSet(
|
return super.createKeyboardLayoutSet(
|
||||||
subtype, emailField, voiceInputKeyEnabled, languageSwitchKeyEnabled);
|
subtype, emailField, voiceInputKeyEnabled, languageSwitchKeyEnabled,
|
||||||
|
splitLayoutEnabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class DvorakUrlCustomizer extends EnglishDvorakCustomizer {
|
private static class DvorakUrlCustomizer extends EnglishDvorakCustomizer {
|
||||||
|
|
|
@ -42,12 +42,13 @@ public class TestsQwertyEmail extends LayoutTestsBase {
|
||||||
@Override
|
@Override
|
||||||
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
||||||
final EditorInfo editorInfo, final boolean voiceInputKeyEnabled,
|
final EditorInfo editorInfo, final boolean voiceInputKeyEnabled,
|
||||||
final boolean languageSwitchKeyEnabled) {
|
final boolean languageSwitchKeyEnabled, final boolean splitLayoutEnabled) {
|
||||||
final EditorInfo emailField = new EditorInfo();
|
final EditorInfo emailField = new EditorInfo();
|
||||||
emailField.inputType =
|
emailField.inputType =
|
||||||
InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_EMAIL_ADDRESS;
|
InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_EMAIL_ADDRESS;
|
||||||
return super.createKeyboardLayoutSet(
|
return super.createKeyboardLayoutSet(
|
||||||
subtype, emailField, voiceInputKeyEnabled, languageSwitchKeyEnabled);
|
subtype, emailField, voiceInputKeyEnabled, languageSwitchKeyEnabled,
|
||||||
|
splitLayoutEnabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class EnglishEmailCustomizer extends EnglishCustomizer {
|
private static class EnglishEmailCustomizer extends EnglishCustomizer {
|
||||||
|
|
|
@ -42,12 +42,13 @@ public class TestsQwertyUrl extends LayoutTestsBase {
|
||||||
@Override
|
@Override
|
||||||
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
||||||
final EditorInfo editorInfo, final boolean voiceInputKeyEnabled,
|
final EditorInfo editorInfo, final boolean voiceInputKeyEnabled,
|
||||||
final boolean languageSwitchKeyEnabled) {
|
final boolean languageSwitchKeyEnabled, final boolean splitLayoutEnabled) {
|
||||||
final EditorInfo emailField = new EditorInfo();
|
final EditorInfo emailField = new EditorInfo();
|
||||||
emailField.inputType =
|
emailField.inputType =
|
||||||
InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_URI;
|
InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_URI;
|
||||||
return super.createKeyboardLayoutSet(
|
return super.createKeyboardLayoutSet(
|
||||||
subtype, emailField, voiceInputKeyEnabled, languageSwitchKeyEnabled);
|
subtype, emailField, voiceInputKeyEnabled, languageSwitchKeyEnabled,
|
||||||
|
splitLayoutEnabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class EnglishUrlCustomizer extends EnglishCustomizer {
|
private static class EnglishUrlCustomizer extends EnglishCustomizer {
|
||||||
|
|
|
@ -0,0 +1,47 @@
|
||||||
|
/*
|
||||||
|
* 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.layout.tests;
|
||||||
|
|
||||||
|
import android.test.suitebuilder.annotation.SmallTest;
|
||||||
|
import android.view.inputmethod.EditorInfo;
|
||||||
|
import android.view.inputmethod.InputMethodSubtype;
|
||||||
|
|
||||||
|
import com.android.inputmethod.keyboard.KeyboardLayoutSet;
|
||||||
|
import com.android.inputmethod.keyboard.layout.LayoutBase;
|
||||||
|
import com.android.inputmethod.keyboard.layout.Qwerty;
|
||||||
|
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* en_US: English (United States)/qwerty - split layout
|
||||||
|
*/
|
||||||
|
@SmallTest
|
||||||
|
public class TestsSplitLayoutQwertyEnglishUS extends LayoutTestsBase {
|
||||||
|
private static final Locale LOCALE = new Locale("en", "US");
|
||||||
|
private static final LayoutBase LAYOUT = new Qwerty(new EnglishSplitCustomizer(LOCALE));
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected KeyboardLayoutSet createKeyboardLayoutSet(final InputMethodSubtype subtype,
|
||||||
|
final EditorInfo editorInfo, final boolean voiceInputKeyEnabled,
|
||||||
|
final boolean languageSwitchKeyEnabled, final boolean splitLayoutEnabled) {
|
||||||
|
return super.createKeyboardLayoutSet(subtype, editorInfo, voiceInputKeyEnabled,
|
||||||
|
languageSwitchKeyEnabled, true /* splitLayoutEnabled */);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
LayoutBase getLayout() { return LAYOUT; }
|
||||||
|
}
|
Loading…
Reference in a new issue