Merge "Fix incorrect remove animation switch status after turned off Talkback"
This commit is contained in:
@@ -16,40 +16,66 @@
|
|||||||
|
|
||||||
package com.android.settings.accessibility;
|
package com.android.settings.accessibility;
|
||||||
|
|
||||||
|
import android.content.ContentResolver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.database.ContentObserver;
|
||||||
|
import android.os.Handler;
|
||||||
|
import android.os.Looper;
|
||||||
|
import android.os.UserHandle;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.text.TextUtils;
|
|
||||||
|
|
||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
import androidx.preference.SwitchPreference;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.TogglePreferenceController;
|
import com.android.settings.core.TogglePreferenceController;
|
||||||
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
|
import com.android.settingslib.core.lifecycle.events.OnStart;
|
||||||
|
import com.android.settingslib.core.lifecycle.events.OnStop;
|
||||||
|
|
||||||
public class DisableAnimationsPreferenceController extends TogglePreferenceController {
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/** A toggle preference controller for disable animations. */
|
||||||
|
public class DisableAnimationsPreferenceController extends TogglePreferenceController implements
|
||||||
|
LifecycleObserver, OnStart, OnStop {
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
static final String ANIMATION_ON_VALUE = "1";
|
static final float ANIMATION_ON_VALUE = 1.0f;
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
static final String ANIMATION_OFF_VALUE = "0";
|
static final float ANIMATION_OFF_VALUE = 0.0f;
|
||||||
|
|
||||||
// Settings that should be changed when toggling animations
|
// Settings that should be changed when toggling animations
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
static final String[] TOGGLE_ANIMATION_TARGETS = {
|
static final List<String> TOGGLE_ANIMATION_TARGETS = Arrays.asList(
|
||||||
Settings.Global.WINDOW_ANIMATION_SCALE, Settings.Global.TRANSITION_ANIMATION_SCALE,
|
Settings.Global.WINDOW_ANIMATION_SCALE, Settings.Global.TRANSITION_ANIMATION_SCALE,
|
||||||
Settings.Global.ANIMATOR_DURATION_SCALE
|
Settings.Global.ANIMATOR_DURATION_SCALE
|
||||||
|
);
|
||||||
|
|
||||||
|
private final ContentObserver mSettingsContentObserver = new ContentObserver(
|
||||||
|
new Handler(Looper.getMainLooper())){
|
||||||
|
@Override
|
||||||
|
public void onChange(boolean selfChange) {
|
||||||
|
updateState(mPreference);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
private final ContentResolver mContentResolver;
|
||||||
|
private SwitchPreference mPreference;
|
||||||
|
|
||||||
public DisableAnimationsPreferenceController(Context context, String preferenceKey) {
|
public DisableAnimationsPreferenceController(Context context, String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
|
mContentResolver = context.getContentResolver();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isChecked() {
|
public boolean isChecked() {
|
||||||
boolean allAnimationsDisabled = true;
|
boolean allAnimationsDisabled = true;
|
||||||
for (String animationSetting : TOGGLE_ANIMATION_TARGETS) {
|
for (String animationSetting : TOGGLE_ANIMATION_TARGETS) {
|
||||||
if (!TextUtils.equals(
|
final float value = Settings.Global.getFloat(mContentResolver, animationSetting,
|
||||||
Settings.Global.getString(mContext.getContentResolver(), animationSetting),
|
ANIMATION_ON_VALUE);
|
||||||
ANIMATION_OFF_VALUE)) {
|
if (value > ANIMATION_OFF_VALUE) {
|
||||||
allAnimationsDisabled = false;
|
allAnimationsDisabled = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -59,11 +85,11 @@ public class DisableAnimationsPreferenceController extends TogglePreferenceContr
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean setChecked(boolean isChecked) {
|
public boolean setChecked(boolean isChecked) {
|
||||||
final String newAnimationValue = isChecked ? ANIMATION_OFF_VALUE : ANIMATION_ON_VALUE;
|
final float newAnimationValue = isChecked ? ANIMATION_OFF_VALUE : ANIMATION_ON_VALUE;
|
||||||
boolean allAnimationSet = true;
|
boolean allAnimationSet = true;
|
||||||
for (String animationPreference : TOGGLE_ANIMATION_TARGETS) {
|
for (String animationPreference : TOGGLE_ANIMATION_TARGETS) {
|
||||||
allAnimationSet &= Settings.Global.putString(mContext.getContentResolver(),
|
allAnimationSet &= Settings.Global.putFloat(mContentResolver, animationPreference,
|
||||||
animationPreference, newAnimationValue);
|
newAnimationValue);
|
||||||
}
|
}
|
||||||
return allAnimationSet;
|
return allAnimationSet;
|
||||||
}
|
}
|
||||||
@@ -77,4 +103,23 @@ public class DisableAnimationsPreferenceController extends TogglePreferenceContr
|
|||||||
public int getSliceHighlightMenuRes() {
|
public int getSliceHighlightMenuRes() {
|
||||||
return R.string.menu_key_accessibility;
|
return R.string.menu_key_accessibility;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
|
super.displayPreference(screen);
|
||||||
|
mPreference = screen.findPreference(getPreferenceKey());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStart() {
|
||||||
|
for (String key : TOGGLE_ANIMATION_TARGETS) {
|
||||||
|
mContentResolver.registerContentObserver(Settings.Global.getUriFor(key),
|
||||||
|
false, mSettingsContentObserver, UserHandle.USER_ALL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStop() {
|
||||||
|
mContentResolver.unregisterContentObserver(mSettingsContentObserver);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -23,8 +23,11 @@ import static com.android.settings.accessibility.DisableAnimationsPreferenceCont
|
|||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.os.Looper;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceManager;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.preference.SwitchPreference;
|
import androidx.preference.SwitchPreference;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||||
@@ -38,15 +41,27 @@ import org.junit.runner.RunWith;
|
|||||||
@RunWith(AndroidJUnit4.class)
|
@RunWith(AndroidJUnit4.class)
|
||||||
public class DisableAnimationsPreferenceControllerTest {
|
public class DisableAnimationsPreferenceControllerTest {
|
||||||
|
|
||||||
private Context mContext;
|
private static final String TEST_PREFERENCE_KEY = "disable_animation";
|
||||||
|
private final Context mContext = ApplicationProvider.getApplicationContext();
|
||||||
|
|
||||||
|
private PreferenceScreen mScreen;
|
||||||
private SwitchPreference mPreference;
|
private SwitchPreference mPreference;
|
||||||
private DisableAnimationsPreferenceController mController;
|
private DisableAnimationsPreferenceController mController;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mContext = ApplicationProvider.getApplicationContext();
|
if (Looper.myLooper() == null) {
|
||||||
mPreference = new SwitchPreference(mContext);
|
Looper.prepare();
|
||||||
mController = new DisableAnimationsPreferenceController(mContext, "disable_animation");
|
}
|
||||||
|
PreferenceManager preferenceManager = new PreferenceManager(mContext);
|
||||||
|
mScreen = preferenceManager.createPreferenceScreen(mContext);
|
||||||
|
final SwitchPreference preference = new SwitchPreference(mContext);
|
||||||
|
preference.setKey(TEST_PREFERENCE_KEY);
|
||||||
|
mScreen.addPreference(preference);
|
||||||
|
|
||||||
|
mController = new DisableAnimationsPreferenceController(mContext, TEST_PREFERENCE_KEY);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
mPreference = mScreen.findPreference(TEST_PREFERENCE_KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -57,10 +72,7 @@ public class DisableAnimationsPreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isChecked_enabledAnimation_shouldReturnFalse() {
|
public void isChecked_enabledAnimation_shouldReturnFalse() {
|
||||||
for (String animationPreference : TOGGLE_ANIMATION_TARGETS) {
|
setAnimationScale(ANIMATION_ON_VALUE);
|
||||||
Settings.Global.putString(mContext.getContentResolver(), animationPreference,
|
|
||||||
ANIMATION_ON_VALUE);
|
|
||||||
}
|
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
@@ -70,10 +82,7 @@ public class DisableAnimationsPreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isChecked_disabledAnimation_shouldReturnTrue() {
|
public void isChecked_disabledAnimation_shouldReturnTrue() {
|
||||||
for (String animationPreference : TOGGLE_ANIMATION_TARGETS) {
|
setAnimationScale(ANIMATION_OFF_VALUE);
|
||||||
Settings.Global.putString(mContext.getContentResolver(), animationPreference,
|
|
||||||
ANIMATION_OFF_VALUE);
|
|
||||||
}
|
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
@@ -86,8 +95,9 @@ public class DisableAnimationsPreferenceControllerTest {
|
|||||||
mController.setChecked(true);
|
mController.setChecked(true);
|
||||||
|
|
||||||
for (String animationSetting : TOGGLE_ANIMATION_TARGETS) {
|
for (String animationSetting : TOGGLE_ANIMATION_TARGETS) {
|
||||||
assertThat(Settings.Global.getString(mContext.getContentResolver(), animationSetting))
|
final float value = Settings.Global.getFloat(mContext.getContentResolver(),
|
||||||
.isEqualTo(ANIMATION_OFF_VALUE);
|
animationSetting, /* def= */ -1.0f);
|
||||||
|
assertThat(Float.compare(value, ANIMATION_OFF_VALUE)).isEqualTo(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -96,8 +106,47 @@ public class DisableAnimationsPreferenceControllerTest {
|
|||||||
mController.setChecked(false);
|
mController.setChecked(false);
|
||||||
|
|
||||||
for (String animationSetting : TOGGLE_ANIMATION_TARGETS) {
|
for (String animationSetting : TOGGLE_ANIMATION_TARGETS) {
|
||||||
assertThat(Settings.Global.getString(mContext.getContentResolver(), animationSetting))
|
final float value = Settings.Global.getFloat(mContext.getContentResolver(),
|
||||||
.isEqualTo(ANIMATION_ON_VALUE);
|
animationSetting, /* def= */ -1.0f);
|
||||||
|
assertThat(Float.compare(value, ANIMATION_ON_VALUE)).isEqualTo(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
@Test
|
||||||
|
public void onStart_enabledAnimation_shouldReturnFalse() {
|
||||||
|
mController.onStart();
|
||||||
|
|
||||||
|
setAnimationScale(ANIMATION_ON_VALUE);
|
||||||
|
|
||||||
|
assertThat(mController.isChecked()).isFalse();
|
||||||
|
assertThat(mPreference.isChecked()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onStart_disabledAnimation_shouldReturnTrue() {
|
||||||
|
mController.onStart();
|
||||||
|
|
||||||
|
setAnimationScale(ANIMATION_OFF_VALUE);
|
||||||
|
|
||||||
|
assertThat(mController.isChecked()).isTrue();
|
||||||
|
assertThat(mPreference.isChecked()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onStop_shouldNotUpdateTargets() {
|
||||||
|
mPreference.setChecked(true);
|
||||||
|
mController.onStart();
|
||||||
|
mController.onStop();
|
||||||
|
|
||||||
|
setAnimationScale(ANIMATION_ON_VALUE);
|
||||||
|
|
||||||
|
assertThat(mPreference.isChecked()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setAnimationScale(float newValue) {
|
||||||
|
for (String animationPreference : TOGGLE_ANIMATION_TARGETS) {
|
||||||
|
Settings.Global.putFloat(mContext.getContentResolver(), animationPreference,
|
||||||
|
newValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user