Fix jank when dismissing InputMethodAndSubtypeEnabler.
InputMethodAndSubtypeUtil#saveInputMethodSubtypeList() has a bug that it saves implicitly enabled subtypes when "Use system languages" is checked. Implicitly enabled subtypes are transient data and the system should have only a null data (0) in the persistent strage. The root cause of this bug is that the method in question has not checked whether the preference item is in enabled (not grayed-out). If it is grayed-out, its checked state does not mean that the user manually checked that subtype but it is just an indicator for the user. The strange UI jank when dismissing InputMethodAndSubtypeEnabler is one of the victim of the above bug because we have worked around it by actually changing checked state before calling the method in question. With this CL we no longer need to update preference items in InputMethodAndSubtypeEnabler#onPause(). Bug: 27867966 Change-Id: Ifc291d77ea41a988438765b9ba16bc5d18a15e1b
This commit is contained in:
@@ -121,8 +121,6 @@ public class InputMethodAndSubtypeEnabler extends SettingsPreferenceFragment
|
|||||||
@Override
|
@Override
|
||||||
public void onPause() {
|
public void onPause() {
|
||||||
super.onPause();
|
super.onPause();
|
||||||
// Clear all subtypes of all IMEs to make sure
|
|
||||||
updateImplicitlyEnabledSubtypes(null /* targetImiId */, false /* check */);
|
|
||||||
InputMethodAndSubtypeUtil.saveInputMethodSubtypeList(this, getContentResolver(),
|
InputMethodAndSubtypeUtil.saveInputMethodSubtypeList(this, getContentResolver(),
|
||||||
mInputMethodInfoList, mHaveHardKeyboard);
|
mInputMethodInfoList, mHaveHardKeyboard);
|
||||||
}
|
}
|
||||||
|
@@ -209,7 +209,12 @@ class InputMethodAndSubtypeUtil {
|
|||||||
needsToResetSelectedSubtype = true;
|
needsToResetSelectedSubtype = true;
|
||||||
subtypePrefFound = true;
|
subtypePrefFound = true;
|
||||||
}
|
}
|
||||||
if (subtypePref.isChecked()) {
|
// Checking <code>subtypePref.isEnabled()</code> is insufficient to determine
|
||||||
|
// whether the user manually enabled this subtype or not. Implicitly-enabled
|
||||||
|
// subtypes are also checked just as an indicator to users. We also need to
|
||||||
|
// check <code>subtypePref.isEnabled()</code> so that only manually enabled
|
||||||
|
// subtypes can be saved here.
|
||||||
|
if (subtypePref.isEnabled() && subtypePref.isChecked()) {
|
||||||
subtypesSet.add(subtypeHashCodeStr);
|
subtypesSet.add(subtypeHashCodeStr);
|
||||||
if (isCurrentInputMethod) {
|
if (isCurrentInputMethod) {
|
||||||
if (selectedInputMethodSubtype == subtype.hashCode()) {
|
if (selectedInputMethodSubtype == subtype.hashCode()) {
|
||||||
|
Reference in New Issue
Block a user