Applies magnification capability settings key

Bug: 144327603
Test: make RunSettingsRoboTests
Change-Id: I45cfc9ce646c8d0c9aaaeaa1cb073fb2ae1ec3de
This commit is contained in:
mincheli
2020-04-08 14:27:16 +08:00
committed by Minche Li
parent 5c108a0b27
commit c419cc6804
2 changed files with 19 additions and 31 deletions

View File

@@ -25,7 +25,6 @@ import android.provider.Settings;
import android.view.View; import android.view.View;
import android.widget.CheckBox; import android.widget.CheckBox;
import androidx.annotation.IntDef;
import androidx.appcompat.app.AlertDialog; import androidx.appcompat.app.AlertDialog;
import androidx.preference.Preference; import androidx.preference.Preference;
@@ -36,21 +35,19 @@ import com.android.settingslib.search.SearchIndexable;
import com.google.common.primitives.Ints; import com.google.common.primitives.Ints;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
/** Settings page for magnification. */ /** Settings page for magnification. */
@SearchIndexable @SearchIndexable
public class MagnificationSettingsFragment extends DashboardFragment { public class MagnificationSettingsFragment extends DashboardFragment {
private static final String TAG = "MagnificationSettingsFragment"; private static final String TAG = "MagnificationSettingsFragment";
private static final String PREF_KEY_MODE = "magnification_mode"; private static final String PREF_KEY_MODE = "magnification_mode";
// TODO(b/146019459): Use magnification_capability. private static final String KEY_CAPABILITY =
private static final String KEY_CAPABILITY = Settings.System.MASTER_MONO; Settings.Secure.ACCESSIBILITY_MAGNIFICATION_CAPABILITY;
private static final int DIALOG_MAGNIFICATION_CAPABILITY = 1; private static final int DIALOG_MAGNIFICATION_CAPABILITY = 1;
private static final String EXTRA_CAPABILITY = "capability"; private static final String EXTRA_CAPABILITY = "capability";
private static final int NONE = 0;
private Preference mModePreference; private Preference mModePreference;
private int mCapabilities = MagnifyMode.NONE; private int mCapabilities = NONE;
private CheckBox mMagnifyFullScreenCheckBox; private CheckBox mMagnifyFullScreenCheckBox;
private CheckBox mMagnifyWindowCheckBox; private CheckBox mMagnifyWindowCheckBox;
@@ -67,7 +64,8 @@ public class MagnificationSettingsFragment extends DashboardFragment {
} }
private static int getMagnificationCapabilities(Context context) { private static int getMagnificationCapabilities(Context context) {
return getSecureIntValue(context, KEY_CAPABILITY, MagnifyMode.FULLSCREEN); return getSecureIntValue(context, KEY_CAPABILITY,
Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_FULLSCREEN);
} }
private static int getSecureIntValue(Context context, String key, int defaultValue) { private static int getSecureIntValue(Context context, String key, int defaultValue) {
@@ -91,9 +89,9 @@ public class MagnificationSettingsFragment extends DashboardFragment {
public void onActivityCreated(Bundle savedInstanceState) { public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState); super.onActivityCreated(savedInstanceState);
if (savedInstanceState != null) { if (savedInstanceState != null) {
mCapabilities = savedInstanceState.getInt(EXTRA_CAPABILITY, MagnifyMode.NONE); mCapabilities = savedInstanceState.getInt(EXTRA_CAPABILITY, NONE);
} }
if (mCapabilities == MagnifyMode.NONE) { if (mCapabilities == NONE) {
mCapabilities = getMagnificationCapabilities(getPrefContext()); mCapabilities = getMagnificationCapabilities(getPrefContext());
} }
} }
@@ -161,8 +159,10 @@ public class MagnificationSettingsFragment extends DashboardFragment {
} }
private void updateAlertDialogCheckState() { private void updateAlertDialogCheckState() {
updateCheckStatus(mMagnifyWindowCheckBox, MagnifyMode.WINDOW); updateCheckStatus(mMagnifyWindowCheckBox,
updateCheckStatus(mMagnifyFullScreenCheckBox, MagnifyMode.FULLSCREEN); Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_WINDOW);
updateCheckStatus(mMagnifyFullScreenCheckBox,
Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_FULLSCREEN);
} }
@@ -175,7 +175,7 @@ public class MagnificationSettingsFragment extends DashboardFragment {
} }
private void updateAlertDialogEnableState() { private void updateAlertDialogEnableState() {
if (mCapabilities != MagnifyMode.ALL) { if (mCapabilities != Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_ALL) {
disableEnabledMagnificationModePreference(); disableEnabledMagnificationModePreference();
} else { } else {
enableAllPreference(); enableAllPreference();
@@ -198,8 +198,10 @@ public class MagnificationSettingsFragment extends DashboardFragment {
private void updateCapabilities(boolean saveToDB) { private void updateCapabilities(boolean saveToDB) {
int capabilities = 0; int capabilities = 0;
capabilities |= capabilities |=
mMagnifyFullScreenCheckBox.isChecked() ? MagnifyMode.FULLSCREEN : 0; mMagnifyFullScreenCheckBox.isChecked()
capabilities |= mMagnifyWindowCheckBox.isChecked() ? MagnifyMode.WINDOW : 0; ? Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_FULLSCREEN : 0;
capabilities |= mMagnifyWindowCheckBox.isChecked()
? Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_WINDOW : 0;
mCapabilities = capabilities; mCapabilities = capabilities;
if (saveToDB) { if (saveToDB) {
setMagnificationCapabilities(capabilities); setMagnificationCapabilities(capabilities);
@@ -215,20 +217,6 @@ public class MagnificationSettingsFragment extends DashboardFragment {
setSecureIntValue(KEY_CAPABILITY, capabilities); setSecureIntValue(KEY_CAPABILITY, capabilities);
} }
@Retention(RetentionPolicy.SOURCE)
@IntDef({
MagnifyMode.NONE,
MagnifyMode.FULLSCREEN,
MagnifyMode.WINDOW,
MagnifyMode.ALL,
})
private @interface MagnifyMode {
int NONE = 0;
int FULLSCREEN = 1;
int WINDOW = 2;
int ALL = 3;
}
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER = public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
new BaseSearchIndexProvider(R.xml.accessibility_magnification_service_settings); new BaseSearchIndexProvider(R.xml.accessibility_magnification_service_settings);
} }

View File

@@ -32,8 +32,8 @@ import org.robolectric.RuntimeEnvironment;
@RunWith(RobolectricTestRunner.class) @RunWith(RobolectricTestRunner.class)
public class MagnificationModePreferenceControllerTest { public class MagnificationModePreferenceControllerTest {
private static final String PREF_KEY = "screen_magnification_mode"; private static final String PREF_KEY = "screen_magnification_mode";
// TODO(b/146019459): Use magnification_capability. private static final String KEY_CAPABILITY =
private static final String KEY_CAPABILITY = Settings.System.MASTER_MONO; Settings.Secure.ACCESSIBILITY_MAGNIFICATION_CAPABILITY;
private static final int WINDOW_SCREEN_VALUE = 2; private static final int WINDOW_SCREEN_VALUE = 2;
private static final int ALL_VALUE = 3; private static final int ALL_VALUE = 3;