Create settings for window magnification (3/n)
This change is for internal test. Add a switch preference for magnification enable mode. Bug: 146019459 Bug: 146473544 Test: make RunSettingsRoboTests ROBOTEST_FILTER=MagnificationEnablePreferenceControllerTest -j64 Change-Id: I85fdbb5b0efc106d5301d95802b8d6b7dbe8145d
This commit is contained in:
@@ -4773,6 +4773,8 @@
|
|||||||
<string name="accessibility_screen_magnification_title">Magnify</string>
|
<string name="accessibility_screen_magnification_title">Magnify</string>
|
||||||
<!-- Title for the accessibility preference screen to edit magnification area. [CHAR LIMIT=35] -->
|
<!-- Title for the accessibility preference screen to edit magnification area. [CHAR LIMIT=35] -->
|
||||||
<string name="accessibility_magnification_mode_title">Magnification area</string>
|
<string name="accessibility_magnification_mode_title">Magnification area</string>
|
||||||
|
<!-- Title for the accessibility preference screen to edit magnification enable mode. [CHAR LIMIT=35] -->
|
||||||
|
<string name="accessibility_magnification_enable_mode_title">Magnification enable</string>
|
||||||
<!-- Message for the accessibility preference screen to edit magnification area dialog. [CHAR LIMIT=none] -->
|
<!-- Message for the accessibility preference screen to edit magnification area dialog. [CHAR LIMIT=none] -->
|
||||||
<string name="accessibility_magnification_area_settings_message">Choose the magnification area(s) you want to use when magnifying the screen</string>
|
<string name="accessibility_magnification_area_settings_message">Choose the magnification area(s) you want to use when magnifying the screen</string>
|
||||||
<!-- Summary for the accessibility preference screen to edit full screen. [CHAR LIMIT=none] -->
|
<!-- Summary for the accessibility preference screen to edit full screen. [CHAR LIMIT=none] -->
|
||||||
@@ -4785,10 +4787,6 @@
|
|||||||
<string name="accessibility_magnification_area_settings_full_screen">Magnify entire screen</string>
|
<string name="accessibility_magnification_area_settings_full_screen">Magnify entire screen</string>
|
||||||
<!-- Message for the accessibility preference screen to edit part of screen. [CHAR LIMIT=none] -->
|
<!-- Message for the accessibility preference screen to edit part of screen. [CHAR LIMIT=none] -->
|
||||||
<string name="accessibility_magnification_area_settings_window_screen">Magnify part of screen</string>
|
<string name="accessibility_magnification_area_settings_window_screen">Magnify part of screen</string>
|
||||||
<!-- Title for the accessibility preference screen to show move controller. [CHAR LIMIT=35] -->
|
|
||||||
<string name="accessibility_magnification_window_control_switch_title">Show move controller</string>
|
|
||||||
<!-- Summary for the accessibility preference screen to show move controller. [CHAR LIMIT=none] -->
|
|
||||||
<string name="accessibility_magnification_window_control_switch_summary">Show a joystick-like controller to move the magnification area</string>
|
|
||||||
<!-- Title for the accessibility preference screen to enable screen magnification settings. [CHAR LIMIT=35] -->
|
<!-- Title for the accessibility preference screen to enable screen magnification settings. [CHAR LIMIT=35] -->
|
||||||
<string name="accessibility_magnification_service_settings_title">Magnification settings</string>
|
<string name="accessibility_magnification_service_settings_title">Magnification settings</string>
|
||||||
<!-- Title for the accessibility preference screen to enable triple-tap gesture screen magnification. [CHAR LIMIT=35] -->
|
<!-- Title for the accessibility preference screen to enable triple-tap gesture screen magnification. [CHAR LIMIT=35] -->
|
||||||
|
@@ -28,9 +28,11 @@
|
|||||||
settings:controller="com.android.settings.accessibility.MagnificationModePreferenceController" />
|
settings:controller="com.android.settings.accessibility.MagnificationModePreferenceController" />
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="magnification_window_control_switch"
|
android:key="magnification_enable"
|
||||||
android:persistent="false"
|
android:persistent="false"
|
||||||
android:summary="@string/accessibility_magnification_window_control_switch_summary"
|
android:title="@string/accessibility_magnification_enable_mode_title"
|
||||||
android:title="@string/accessibility_magnification_window_control_switch_title"
|
android:summaryOn="@string/accessibility_magnification_area_settings_full_screen_summary"
|
||||||
settings:controller="com.android.settings.accessibility.MagnificationWindowControlPreferenceController" />
|
android:summaryOff="@string/accessibility_magnification_area_settings_window_screen_summary"
|
||||||
|
settings:controller="com.android.settings.accessibility.MagnificationEnablePreferenceController" />
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
@@ -0,0 +1,58 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2020 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.accessibility;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.UserHandle;
|
||||||
|
import android.provider.Settings;
|
||||||
|
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.SwitchPreference;
|
||||||
|
|
||||||
|
import com.android.settings.core.TogglePreferenceController;
|
||||||
|
|
||||||
|
/** Controller that shows the magnification enable mode summary. */
|
||||||
|
public class MagnificationEnablePreferenceController extends TogglePreferenceController {
|
||||||
|
|
||||||
|
private static final String KEY_ENABLE = Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE;
|
||||||
|
|
||||||
|
public MagnificationEnablePreferenceController(Context context, String preferenceKey) {
|
||||||
|
super(context, preferenceKey);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isChecked() {
|
||||||
|
final int enableMode = Settings.Secure.getIntForUser(mContext.getContentResolver(),
|
||||||
|
KEY_ENABLE,
|
||||||
|
Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_FULLSCREEN,
|
||||||
|
UserHandle.USER_CURRENT);
|
||||||
|
return enableMode == Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_FULLSCREEN;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean setChecked(boolean isChecked) {
|
||||||
|
final int value = isChecked ? Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_FULLSCREEN
|
||||||
|
: Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_WINDOW;
|
||||||
|
return Settings.Secure.putIntForUser(mContext.getContentResolver(), KEY_ENABLE, value,
|
||||||
|
UserHandle.USER_CURRENT);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getAvailabilityStatus() {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
}
|
@@ -1,60 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2019 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.accessibility;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.os.UserHandle;
|
|
||||||
import android.provider.Settings;
|
|
||||||
|
|
||||||
import com.android.settings.core.TogglePreferenceController;
|
|
||||||
|
|
||||||
import java.lang.annotation.Retention;
|
|
||||||
import java.lang.annotation.RetentionPolicy;
|
|
||||||
|
|
||||||
/** Controller that shows and updates the magnification window control switch. */
|
|
||||||
public class MagnificationWindowControlPreferenceController extends TogglePreferenceController {
|
|
||||||
|
|
||||||
// TODO(b/146019459): Use magnification_window_control_enabled.
|
|
||||||
private static final String KEY_CONTROL = Settings.System.MASTER_MONO;
|
|
||||||
|
|
||||||
public MagnificationWindowControlPreferenceController(Context context, String preferenceKey) {
|
|
||||||
super(context, preferenceKey);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isChecked() {
|
|
||||||
return Settings.System.getIntForUser(mContext.getContentResolver(),
|
|
||||||
KEY_CONTROL, State.OFF, UserHandle.USER_CURRENT) == State.ON;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean setChecked(boolean isChecked) {
|
|
||||||
return Settings.System.putIntForUser(mContext.getContentResolver(),
|
|
||||||
KEY_CONTROL, isChecked ? State.ON : State.OFF, UserHandle.USER_CURRENT);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getAvailabilityStatus() {
|
|
||||||
return AVAILABLE;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Retention(RetentionPolicy.SOURCE)
|
|
||||||
private @interface State {
|
|
||||||
int OFF = 0;
|
|
||||||
int ON = 1;
|
|
||||||
}
|
|
||||||
}
|
|
@@ -256,6 +256,11 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
|||||||
updateAlertDialogCheckState();
|
updateAlertDialogCheckState();
|
||||||
updateAlertDialogEnableState();
|
updateAlertDialogEnableState();
|
||||||
|
|
||||||
|
// Window magnification mode doesn't support advancedView.
|
||||||
|
if (isWindowMagnification(getPrefContext())) {
|
||||||
|
advancedView.setVisibility(View.GONE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
// Shows the triple tap checkbox directly if clicked.
|
// Shows the triple tap checkbox directly if clicked.
|
||||||
if (mTripleTapTypeCheckBox.isChecked()) {
|
if (mTripleTapTypeCheckBox.isChecked()) {
|
||||||
advancedView.setVisibility(View.GONE);
|
advancedView.setVisibility(View.GONE);
|
||||||
@@ -610,4 +615,13 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean isWindowMagnification(Context context) {
|
||||||
|
final int mode = Settings.Secure.getIntForUser(
|
||||||
|
context.getContentResolver(),
|
||||||
|
Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE,
|
||||||
|
Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_FULLSCREEN,
|
||||||
|
context.getContentResolver().getUserId());
|
||||||
|
return mode == Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_WINDOW;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2019 The Android Open Source Project
|
* Copyright (C) 2020 The Android Open Source Project
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
@@ -30,29 +30,27 @@ import org.junit.runner.RunWith;
|
|||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
|
||||||
import java.lang.annotation.Retention;
|
|
||||||
import java.lang.annotation.RetentionPolicy;
|
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class MagnificationWindowControlPreferenceControllerTest {
|
public class MagnificationEnablePreferenceControllerTest {
|
||||||
private static final String PREF_KEY = "screen_magnification_window_control_switch";
|
private static final String PREF_KEY = "screen_magnification_enable";
|
||||||
// TODO(b/146019459): Use magnification_window_control_enabled.
|
private static final String KEY_ENABLE = Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE;
|
||||||
private static final String KEY_CONTROL = Settings.System.MASTER_MONO;
|
private static final int UNKNOWN = -1;
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private SwitchPreference mPreference;
|
private SwitchPreference mPreference;
|
||||||
private MagnificationWindowControlPreferenceController mController;
|
private MagnificationEnablePreferenceController mController;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mContext = RuntimeEnvironment.application;
|
mContext = RuntimeEnvironment.application;
|
||||||
mPreference = new SwitchPreference(mContext);
|
mPreference = new SwitchPreference(mContext);
|
||||||
mController = new MagnificationWindowControlPreferenceController(mContext, PREF_KEY);
|
mController = new MagnificationEnablePreferenceController(mContext, PREF_KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isChecked_enabledWindowControl_shouldReturnTrue() {
|
public void isChecked_enabledFullscreenMagnificationMode_shouldReturnTrue() {
|
||||||
Settings.System.putIntForUser(mContext.getContentResolver(),
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
KEY_CONTROL, State.ON, UserHandle.USER_CURRENT);
|
KEY_ENABLE, Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_FULLSCREEN,
|
||||||
|
UserHandle.USER_CURRENT);
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
@@ -61,9 +59,10 @@ public class MagnificationWindowControlPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isChecked_disabledWindowControl_shouldReturnFalse() {
|
public void isChecked_enabledWindowMagnificationMode_shouldReturnFalse() {
|
||||||
Settings.System.putIntForUser(mContext.getContentResolver(),
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
KEY_CONTROL, State.OFF, UserHandle.USER_CURRENT);
|
KEY_ENABLE, Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_WINDOW,
|
||||||
|
UserHandle.USER_CURRENT);
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
@@ -71,26 +70,24 @@ public class MagnificationWindowControlPreferenceControllerTest {
|
|||||||
assertThat(mPreference.isChecked()).isFalse();
|
assertThat(mPreference.isChecked()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void setChecked_setTrue_shouldEnableWindowControl() {
|
public void setChecked_setTrue_shouldEnableFullscreenMagnificationMode() {
|
||||||
mController.setChecked(true);
|
mController.setChecked(true);
|
||||||
|
|
||||||
assertThat(Settings.System.getIntForUser(mContext.getContentResolver(),
|
assertThat(Settings.Secure.getIntForUser(mContext.getContentResolver(),
|
||||||
KEY_CONTROL, State.UNKNOWN, UserHandle.USER_CURRENT)).isEqualTo(State.ON);
|
KEY_ENABLE, UNKNOWN,
|
||||||
|
UserHandle.USER_CURRENT)).isEqualTo(
|
||||||
|
Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_FULLSCREEN);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void setChecked_setFalse_shouldDisableWindowControl() {
|
public void setChecked_setFalse_shouldEnableWindowMagnificationMode() {
|
||||||
mController.setChecked(false);
|
mController.setChecked(false);
|
||||||
|
|
||||||
assertThat(Settings.System.getIntForUser(mContext.getContentResolver(),
|
assertThat(Settings.Secure.getIntForUser(mContext.getContentResolver(),
|
||||||
KEY_CONTROL, State.UNKNOWN, UserHandle.USER_CURRENT)).isEqualTo(State.OFF);
|
KEY_ENABLE, UNKNOWN,
|
||||||
}
|
UserHandle.USER_CURRENT)).isEqualTo(
|
||||||
|
Settings.Secure.ACCESSIBILITY_MAGNIFICATION_MODE_WINDOW);
|
||||||
@Retention(RetentionPolicy.SOURCE)
|
|
||||||
private @interface State {
|
|
||||||
int UNKNOWN = -1;
|
|
||||||
int OFF = 0;
|
|
||||||
int ON = 1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
Reference in New Issue
Block a user