Make InputMethodAndSubtypeUtil and share utilities by LanguageSettings and InputMethodAndSubtypeUtil
Change-Id: I70b9ce62a87a38054be0fce4234104aee9be9a87
This commit is contained in:
@@ -19,23 +19,18 @@ package com.android.settings;
|
|||||||
import android.app.AlertDialog;
|
import android.app.AlertDialog;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.content.pm.ApplicationInfo;
|
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.preference.CheckBoxPreference;
|
import android.preference.CheckBoxPreference;
|
||||||
import android.preference.Preference;
|
import android.preference.Preference;
|
||||||
import android.preference.PreferenceActivity;
|
|
||||||
import android.preference.PreferenceCategory;
|
import android.preference.PreferenceCategory;
|
||||||
import android.preference.PreferenceScreen;
|
import android.preference.PreferenceScreen;
|
||||||
import android.provider.Settings;
|
|
||||||
import android.text.TextUtils;
|
|
||||||
import android.view.inputmethod.InputMethodInfo;
|
import android.view.inputmethod.InputMethodInfo;
|
||||||
import android.view.inputmethod.InputMethodManager;
|
import android.view.inputmethod.InputMethodManager;
|
||||||
import android.view.inputmethod.InputMethodSubtype;
|
import android.view.inputmethod.InputMethodSubtype;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class InputMethodAndSubtypeEnabler extends SettingsPreferenceFragment {
|
public class InputMethodAndSubtypeEnabler extends SettingsPreferenceFragment {
|
||||||
@@ -44,10 +39,6 @@ public class InputMethodAndSubtypeEnabler extends SettingsPreferenceFragment {
|
|||||||
|
|
||||||
private List<InputMethodInfo> mInputMethodProperties;
|
private List<InputMethodInfo> mInputMethodProperties;
|
||||||
|
|
||||||
private final TextUtils.SimpleStringSplitter mStringColonSplitter
|
|
||||||
= new TextUtils.SimpleStringSplitter(':');
|
|
||||||
|
|
||||||
private String mLastInputMethodId;
|
|
||||||
private String mLastTickedInputMethodId;
|
private String mLastTickedInputMethodId;
|
||||||
|
|
||||||
private AlertDialog mDialog = null;
|
private AlertDialog mDialog = null;
|
||||||
@@ -64,13 +55,15 @@ public class InputMethodAndSubtypeEnabler extends SettingsPreferenceFragment {
|
|||||||
@Override
|
@Override
|
||||||
public void onResume() {
|
public void onResume() {
|
||||||
super.onResume();
|
super.onResume();
|
||||||
loadInputMethodSubtypeList();
|
InputMethodAndSubtypeUtil.loadInputMethodSubtypeList(this, mInputMethodProperties);
|
||||||
|
mLastTickedInputMethodId = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPause() {
|
public void onPause() {
|
||||||
super.onPause();
|
super.onPause();
|
||||||
saveInputMethodSubtypeList();
|
InputMethodAndSubtypeUtil.saveInputMethodSubtypeList(this, mInputMethodProperties,
|
||||||
|
mHaveHardKeyboard, mLastTickedInputMethodId);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -88,8 +81,9 @@ public class InputMethodAndSubtypeEnabler extends SettingsPreferenceFragment {
|
|||||||
InputMethodInfo imi = mInputMethodProperties.get(i);
|
InputMethodInfo imi = mInputMethodProperties.get(i);
|
||||||
if (id.equals(imi.getId())) {
|
if (id.equals(imi.getId())) {
|
||||||
selImi = imi;
|
selImi = imi;
|
||||||
if (isSystemIme(imi)) {
|
if (InputMethodAndSubtypeUtil.isSystemIme(imi)) {
|
||||||
setSubtypesPreferenceEnabled(id, true);
|
InputMethodAndSubtypeUtil.setSubtypesPreferenceEnabled(
|
||||||
|
this, mInputMethodProperties, id, true);
|
||||||
// This is a built-in IME, so no need to warn.
|
// This is a built-in IME, so no need to warn.
|
||||||
mLastTickedInputMethodId = id;
|
mLastTickedInputMethodId = id;
|
||||||
return super.onPreferenceTreeClick(preferenceScreen, preference);
|
return super.onPreferenceTreeClick(preferenceScreen, preference);
|
||||||
@@ -110,7 +104,9 @@ public class InputMethodAndSubtypeEnabler extends SettingsPreferenceFragment {
|
|||||||
new DialogInterface.OnClickListener() {
|
new DialogInterface.OnClickListener() {
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
chkPref.setChecked(true);
|
chkPref.setChecked(true);
|
||||||
setSubtypesPreferenceEnabled(id, true);
|
InputMethodAndSubtypeUtil.setSubtypesPreferenceEnabled(
|
||||||
|
InputMethodAndSubtypeEnabler.this,
|
||||||
|
mInputMethodProperties, id, true);
|
||||||
mLastTickedInputMethodId = id;
|
mLastTickedInputMethodId = id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -135,7 +131,8 @@ public class InputMethodAndSubtypeEnabler extends SettingsPreferenceFragment {
|
|||||||
if (id.equals(mLastTickedInputMethodId)) {
|
if (id.equals(mLastTickedInputMethodId)) {
|
||||||
mLastTickedInputMethodId = null;
|
mLastTickedInputMethodId = null;
|
||||||
}
|
}
|
||||||
setSubtypesPreferenceEnabled(id, false);
|
InputMethodAndSubtypeUtil.setSubtypesPreferenceEnabled(
|
||||||
|
this, mInputMethodProperties, id, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return super.onPreferenceTreeClick(preferenceScreen, preference);
|
return super.onPreferenceTreeClick(preferenceScreen, preference);
|
||||||
@@ -156,9 +153,6 @@ public class InputMethodAndSubtypeEnabler extends SettingsPreferenceFragment {
|
|||||||
|
|
||||||
// TODO: Change mInputMethodProperties to Map
|
// TODO: Change mInputMethodProperties to Map
|
||||||
mInputMethodProperties = imm.getInputMethodList();
|
mInputMethodProperties = imm.getInputMethodList();
|
||||||
|
|
||||||
mLastInputMethodId = Settings.Secure.getString(getContentResolver(),
|
|
||||||
Settings.Secure.DEFAULT_INPUT_METHOD);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private PreferenceScreen createPreferenceHierarchy() {
|
private PreferenceScreen createPreferenceHierarchy() {
|
||||||
@@ -175,7 +169,7 @@ public class InputMethodAndSubtypeEnabler extends SettingsPreferenceFragment {
|
|||||||
|
|
||||||
PackageManager pm = getPackageManager();
|
PackageManager pm = getPackageManager();
|
||||||
CharSequence label = property.loadLabel(pm);
|
CharSequence label = property.loadLabel(pm);
|
||||||
boolean systemIME = isSystemIme(property);
|
boolean systemIME = InputMethodAndSubtypeUtil.isSystemIme(property);
|
||||||
|
|
||||||
keyboardSettingsCategory.setTitle(label);
|
keyboardSettingsCategory.setTitle(label);
|
||||||
|
|
||||||
@@ -220,100 +214,4 @@ public class InputMethodAndSubtypeEnabler extends SettingsPreferenceFragment {
|
|||||||
}
|
}
|
||||||
return root;
|
return root;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void loadInputMethodSubtypeList() {
|
|
||||||
final HashSet<String> enabled = new HashSet<String>();
|
|
||||||
String enabledStr = Settings.Secure.getString(getContentResolver(),
|
|
||||||
Settings.Secure.ENABLED_INPUT_METHODS);
|
|
||||||
if (enabledStr != null) {
|
|
||||||
final TextUtils.SimpleStringSplitter splitter = mStringColonSplitter;
|
|
||||||
splitter.setString(enabledStr);
|
|
||||||
while (splitter.hasNext()) {
|
|
||||||
enabled.add(splitter.next());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update the statuses of the Check Boxes.
|
|
||||||
int N = mInputMethodProperties.size();
|
|
||||||
// TODO: Use iterator.
|
|
||||||
for (int i = 0; i < N; ++i) {
|
|
||||||
final String id = mInputMethodProperties.get(i).getId();
|
|
||||||
CheckBoxPreference pref = (CheckBoxPreference) findPreference(
|
|
||||||
mInputMethodProperties.get(i).getId());
|
|
||||||
if (pref != null) {
|
|
||||||
boolean isEnabled = enabled.contains(id);
|
|
||||||
pref.setChecked(isEnabled);
|
|
||||||
setSubtypesPreferenceEnabled(id, isEnabled);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
mLastTickedInputMethodId = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void saveInputMethodSubtypeList() {
|
|
||||||
StringBuilder builder = new StringBuilder();
|
|
||||||
StringBuilder disabledSysImes = new StringBuilder();
|
|
||||||
|
|
||||||
int firstEnabled = -1;
|
|
||||||
int N = mInputMethodProperties.size();
|
|
||||||
for (int i = 0; i < N; ++i) {
|
|
||||||
final InputMethodInfo property = mInputMethodProperties.get(i);
|
|
||||||
final String id = property.getId();
|
|
||||||
CheckBoxPreference pref = (CheckBoxPreference) findPreference(id);
|
|
||||||
boolean currentInputMethod = id.equals(mLastInputMethodId);
|
|
||||||
boolean systemIme = isSystemIme(property);
|
|
||||||
// TODO: Append subtypes by using the separator ";"
|
|
||||||
if (((N == 1 || systemIme) && !mHaveHardKeyboard)
|
|
||||||
|| (pref != null && pref.isChecked())) {
|
|
||||||
if (builder.length() > 0) builder.append(':');
|
|
||||||
builder.append(id);
|
|
||||||
if (firstEnabled < 0) {
|
|
||||||
firstEnabled = i;
|
|
||||||
}
|
|
||||||
} else if (currentInputMethod) {
|
|
||||||
mLastInputMethodId = mLastTickedInputMethodId;
|
|
||||||
}
|
|
||||||
// If it's a disabled system ime, add it to the disabled list so that it
|
|
||||||
// doesn't get enabled automatically on any changes to the package list
|
|
||||||
if (pref != null && !pref.isChecked() && systemIme && mHaveHardKeyboard) {
|
|
||||||
if (disabledSysImes.length() > 0) disabledSysImes.append(":");
|
|
||||||
disabledSysImes.append(id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the last input method is unset, set it as the first enabled one.
|
|
||||||
if (TextUtils.isEmpty(mLastInputMethodId)) {
|
|
||||||
if (firstEnabled >= 0) {
|
|
||||||
mLastInputMethodId = mInputMethodProperties.get(firstEnabled).getId();
|
|
||||||
} else {
|
|
||||||
mLastInputMethodId = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Settings.Secure.putString(getContentResolver(),
|
|
||||||
Settings.Secure.ENABLED_INPUT_METHODS, builder.toString());
|
|
||||||
Settings.Secure.putString(getContentResolver(),
|
|
||||||
Settings.Secure.DISABLED_SYSTEM_INPUT_METHODS, disabledSysImes.toString());
|
|
||||||
Settings.Secure.putString(getContentResolver(),
|
|
||||||
Settings.Secure.DEFAULT_INPUT_METHOD,
|
|
||||||
mLastInputMethodId != null ? mLastInputMethodId : "");
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setSubtypesPreferenceEnabled(String id, boolean enabled) {
|
|
||||||
PreferenceScreen preferenceScreen = getPreferenceScreen();
|
|
||||||
final int N = mInputMethodProperties.size();
|
|
||||||
// TODO: Use iterator.
|
|
||||||
for (int i = 0; i < N; i++) {
|
|
||||||
InputMethodInfo imi = mInputMethodProperties.get(i);
|
|
||||||
if (id.equals(imi.getId())) {
|
|
||||||
for (InputMethodSubtype subtype: imi.getSubtypes()) {
|
|
||||||
preferenceScreen.findPreference(id + subtype.hashCode()).setEnabled(enabled);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean isSystemIme(InputMethodInfo property) {
|
|
||||||
return (property.getServiceInfo().applicationInfo.flags
|
|
||||||
& ApplicationInfo.FLAG_SYSTEM) != 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
135
src/com/android/settings/InputMethodAndSubtypeUtil.java
Normal file
135
src/com/android/settings/InputMethodAndSubtypeUtil.java
Normal file
@@ -0,0 +1,135 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2010 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.settings;
|
||||||
|
|
||||||
|
import android.content.pm.ApplicationInfo;
|
||||||
|
import android.preference.CheckBoxPreference;
|
||||||
|
import android.preference.PreferenceScreen;
|
||||||
|
import android.provider.Settings;
|
||||||
|
import android.text.TextUtils;
|
||||||
|
import android.view.inputmethod.InputMethodInfo;
|
||||||
|
import android.view.inputmethod.InputMethodSubtype;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class InputMethodAndSubtypeUtil {
|
||||||
|
|
||||||
|
private static final TextUtils.SimpleStringSplitter sStringColonSplitter
|
||||||
|
= new TextUtils.SimpleStringSplitter(':');
|
||||||
|
|
||||||
|
public static void saveInputMethodSubtypeList(
|
||||||
|
SettingsPreferenceFragment context, List<InputMethodInfo> inputMethodProperties,
|
||||||
|
boolean hasHardKeyboard, String lastTickedInputMethodId) {
|
||||||
|
String lastInputMethodId = Settings.Secure.getString(context.getContentResolver(),
|
||||||
|
Settings.Secure.DEFAULT_INPUT_METHOD);
|
||||||
|
|
||||||
|
StringBuilder builder = new StringBuilder();
|
||||||
|
StringBuilder disabledSysImes = new StringBuilder();
|
||||||
|
|
||||||
|
int firstEnabled = -1;
|
||||||
|
int N = inputMethodProperties.size();
|
||||||
|
for (int i = 0; i < N; ++i) {
|
||||||
|
final InputMethodInfo property = inputMethodProperties.get(i);
|
||||||
|
final String id = property.getId();
|
||||||
|
CheckBoxPreference pref = (CheckBoxPreference) context.findPreference(id);
|
||||||
|
boolean currentInputMethod = id.equals(lastInputMethodId);
|
||||||
|
boolean systemIme = isSystemIme(property);
|
||||||
|
// TODO: Append subtypes by using the separator ";"
|
||||||
|
if (((N == 1 || systemIme) && !hasHardKeyboard)
|
||||||
|
|| (pref != null && pref.isChecked())) {
|
||||||
|
if (builder.length() > 0) builder.append(':');
|
||||||
|
builder.append(id);
|
||||||
|
if (firstEnabled < 0) {
|
||||||
|
firstEnabled = i;
|
||||||
|
}
|
||||||
|
} else if (currentInputMethod) {
|
||||||
|
lastInputMethodId = lastTickedInputMethodId;
|
||||||
|
}
|
||||||
|
// If it's a disabled system ime, add it to the disabled list so that it
|
||||||
|
// doesn't get enabled automatically on any changes to the package list
|
||||||
|
if (pref != null && !pref.isChecked() && systemIme && hasHardKeyboard) {
|
||||||
|
if (disabledSysImes.length() > 0) disabledSysImes.append(":");
|
||||||
|
disabledSysImes.append(id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// If the last input method is unset, set it as the first enabled one.
|
||||||
|
if (TextUtils.isEmpty(lastInputMethodId)) {
|
||||||
|
if (firstEnabled >= 0) {
|
||||||
|
lastInputMethodId = inputMethodProperties.get(firstEnabled).getId();
|
||||||
|
} else {
|
||||||
|
lastInputMethodId = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Settings.Secure.putString(context.getContentResolver(),
|
||||||
|
Settings.Secure.ENABLED_INPUT_METHODS, builder.toString());
|
||||||
|
Settings.Secure.putString(context.getContentResolver(),
|
||||||
|
Settings.Secure.DISABLED_SYSTEM_INPUT_METHODS, disabledSysImes.toString());
|
||||||
|
Settings.Secure.putString(context.getContentResolver(),
|
||||||
|
Settings.Secure.DEFAULT_INPUT_METHOD,
|
||||||
|
lastInputMethodId != null ? lastInputMethodId : "");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void loadInputMethodSubtypeList(SettingsPreferenceFragment context,
|
||||||
|
List<InputMethodInfo> inputMethodProperties) {
|
||||||
|
final HashSet<String> enabled = new HashSet<String>();
|
||||||
|
String enabledStr = Settings.Secure.getString(context.getContentResolver(),
|
||||||
|
Settings.Secure.ENABLED_INPUT_METHODS);
|
||||||
|
if (enabledStr != null) {
|
||||||
|
final TextUtils.SimpleStringSplitter splitter = sStringColonSplitter;
|
||||||
|
splitter.setString(enabledStr);
|
||||||
|
while (splitter.hasNext()) {
|
||||||
|
enabled.add(splitter.next());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update the statuses of the Check Boxes.
|
||||||
|
int N = inputMethodProperties.size();
|
||||||
|
// TODO: Use iterator.
|
||||||
|
for (int i = 0; i < N; ++i) {
|
||||||
|
final String id = inputMethodProperties.get(i).getId();
|
||||||
|
CheckBoxPreference pref = (CheckBoxPreference) context.findPreference(
|
||||||
|
inputMethodProperties.get(i).getId());
|
||||||
|
if (pref != null) {
|
||||||
|
boolean isEnabled = enabled.contains(id);
|
||||||
|
pref.setChecked(isEnabled);
|
||||||
|
setSubtypesPreferenceEnabled(context, inputMethodProperties, id, isEnabled);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void setSubtypesPreferenceEnabled(SettingsPreferenceFragment context,
|
||||||
|
List<InputMethodInfo> inputMethodProperties, String id, boolean enabled) {
|
||||||
|
PreferenceScreen preferenceScreen = context.getPreferenceScreen();
|
||||||
|
final int N = inputMethodProperties.size();
|
||||||
|
// TODO: Use iterator.
|
||||||
|
for (int i = 0; i < N; i++) {
|
||||||
|
InputMethodInfo imi = inputMethodProperties.get(i);
|
||||||
|
if (id.equals(imi.getId())) {
|
||||||
|
for (InputMethodSubtype subtype: imi.getSubtypes()) {
|
||||||
|
preferenceScreen.findPreference(id + subtype.hashCode()).setEnabled(enabled);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static boolean isSystemIme(InputMethodInfo property) {
|
||||||
|
return (property.getServiceInfo().applicationInfo.flags
|
||||||
|
& ApplicationInfo.FLAG_SYSTEM) != 0;
|
||||||
|
}
|
||||||
|
}
|
@@ -16,7 +16,6 @@
|
|||||||
|
|
||||||
package com.android.settings;
|
package com.android.settings;
|
||||||
|
|
||||||
import android.app.Activity;
|
|
||||||
import android.app.AlertDialog;
|
import android.app.AlertDialog;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
@@ -28,14 +27,11 @@ import android.preference.CheckBoxPreference;
|
|||||||
import android.preference.Preference;
|
import android.preference.Preference;
|
||||||
import android.preference.PreferenceGroup;
|
import android.preference.PreferenceGroup;
|
||||||
import android.preference.PreferenceScreen;
|
import android.preference.PreferenceScreen;
|
||||||
import android.provider.Settings;
|
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.Log;
|
|
||||||
import android.view.inputmethod.InputMethodInfo;
|
import android.view.inputmethod.InputMethodInfo;
|
||||||
import android.view.inputmethod.InputMethodManager;
|
import android.view.inputmethod.InputMethodManager;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class LanguageSettings extends SettingsPreferenceFragment {
|
public class LanguageSettings extends SettingsPreferenceFragment {
|
||||||
@@ -92,7 +88,8 @@ public class LanguageSettings extends SettingsPreferenceFragment {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void onCreateIMM() {
|
private void onCreateIMM() {
|
||||||
InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
|
InputMethodManager imm = (InputMethodManager) getSystemService(
|
||||||
|
Context.INPUT_METHOD_SERVICE);
|
||||||
|
|
||||||
mInputMethodProperties = imm.getInputMethodList();
|
mInputMethodProperties = imm.getInputMethodList();
|
||||||
|
|
||||||
@@ -143,27 +140,7 @@ public class LanguageSettings extends SettingsPreferenceFragment {
|
|||||||
public void onResume() {
|
public void onResume() {
|
||||||
super.onResume();
|
super.onResume();
|
||||||
|
|
||||||
final HashSet<String> enabled = new HashSet<String>();
|
InputMethodAndSubtypeUtil.loadInputMethodSubtypeList(this, mInputMethodProperties);
|
||||||
String enabledStr = Settings.Secure.getString(getContentResolver(),
|
|
||||||
Settings.Secure.ENABLED_INPUT_METHODS);
|
|
||||||
if (enabledStr != null) {
|
|
||||||
final TextUtils.SimpleStringSplitter splitter = mStringColonSplitter;
|
|
||||||
splitter.setString(enabledStr);
|
|
||||||
while (splitter.hasNext()) {
|
|
||||||
enabled.add(splitter.next());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update the statuses of the Check Boxes.
|
|
||||||
int N = mInputMethodProperties.size();
|
|
||||||
for (int i = 0; i < N; ++i) {
|
|
||||||
final String id = mInputMethodProperties.get(i).getId();
|
|
||||||
CheckBoxPreference pref = (CheckBoxPreference) findPreference(mInputMethodProperties
|
|
||||||
.get(i).getId());
|
|
||||||
if (pref != null) {
|
|
||||||
pref.setChecked(enabled.contains(id));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
mLastTickedInputMethodId = null;
|
mLastTickedInputMethodId = null;
|
||||||
|
|
||||||
if (mLanguagePref != null) {
|
if (mLanguagePref != null) {
|
||||||
@@ -179,55 +156,8 @@ public class LanguageSettings extends SettingsPreferenceFragment {
|
|||||||
@Override
|
@Override
|
||||||
public void onPause() {
|
public void onPause() {
|
||||||
super.onPause();
|
super.onPause();
|
||||||
|
InputMethodAndSubtypeUtil.saveInputMethodSubtypeList(this, mInputMethodProperties,
|
||||||
String lastInputMethodId = Settings.Secure.getString(getContentResolver(),
|
mHaveHardKeyboard, mLastTickedInputMethodId);
|
||||||
Settings.Secure.DEFAULT_INPUT_METHOD);
|
|
||||||
|
|
||||||
StringBuilder builder = new StringBuilder();
|
|
||||||
StringBuilder disabledSysImes = new StringBuilder();
|
|
||||||
|
|
||||||
int firstEnabled = -1;
|
|
||||||
int N = mInputMethodProperties.size();
|
|
||||||
for (int i = 0; i < N; ++i) {
|
|
||||||
final InputMethodInfo property = mInputMethodProperties.get(i);
|
|
||||||
final String id = property.getId();
|
|
||||||
CheckBoxPreference pref = (CheckBoxPreference) findPreference(id);
|
|
||||||
boolean hasIt = id.equals(lastInputMethodId);
|
|
||||||
boolean systemIme = isSystemIme(property);
|
|
||||||
if (((N == 1 || systemIme) && !mHaveHardKeyboard)
|
|
||||||
|| (pref != null && pref.isChecked())) {
|
|
||||||
if (builder.length() > 0) builder.append(':');
|
|
||||||
builder.append(id);
|
|
||||||
if (firstEnabled < 0) {
|
|
||||||
firstEnabled = i;
|
|
||||||
}
|
|
||||||
} else if (hasIt) {
|
|
||||||
lastInputMethodId = mLastTickedInputMethodId;
|
|
||||||
}
|
|
||||||
// If it's a disabled system ime, add it to the disabled list so that it
|
|
||||||
// doesn't get enabled automatically on any changes to the package list
|
|
||||||
if (pref != null && !pref.isChecked() && systemIme && mHaveHardKeyboard) {
|
|
||||||
if (disabledSysImes.length() > 0) disabledSysImes.append(":");
|
|
||||||
disabledSysImes.append(id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the last input method is unset, set it as the first enabled one.
|
|
||||||
if (null == lastInputMethodId || "".equals(lastInputMethodId)) {
|
|
||||||
if (firstEnabled >= 0) {
|
|
||||||
lastInputMethodId = mInputMethodProperties.get(firstEnabled).getId();
|
|
||||||
} else {
|
|
||||||
lastInputMethodId = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Settings.Secure.putString(getContentResolver(),
|
|
||||||
Settings.Secure.ENABLED_INPUT_METHODS, builder.toString());
|
|
||||||
Settings.Secure.putString(getContentResolver(),
|
|
||||||
Settings.Secure.DISABLED_SYSTEM_INPUT_METHODS, disabledSysImes.toString());
|
|
||||||
Settings.Secure.putString(getContentResolver(),
|
|
||||||
Settings.Secure.DEFAULT_INPUT_METHOD,
|
|
||||||
lastInputMethodId != null ? lastInputMethodId : "");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Reference in New Issue
Block a user