Create settings for window magnification (2/n)
Provide a setting for new Magnify area feature and joystick controller Bug: 146019459 Bug: 146473544 Test: make RunSettingsRoboTests ROBOTEST_FILTER=MagnificationModePreferenceControllerTest Test: make RunSettingsRoboTests ROBOTEST_FILTER=MagnificationWindowControlPreferenceControllerTest Test: make RunSettingsRoboTests2 Change-Id: Ia32fa073c59ad304e9ef9eb530ba37dd24c2f2f6
This commit is contained in:
@@ -24,6 +24,7 @@ import android.content.res.TypedArray;
|
||||
import android.graphics.drawable.Drawable;
|
||||
import android.text.Spannable;
|
||||
import android.text.SpannableString;
|
||||
import android.text.TextUtils;
|
||||
import android.text.style.ImageSpan;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
@@ -53,13 +54,15 @@ public class AccessibilityEditDialogUtils {
|
||||
*/
|
||||
@Retention(RetentionPolicy.SOURCE)
|
||||
@IntDef({
|
||||
DialogType.EDIT_SHORTCUT_GENERIC,
|
||||
DialogType.EDIT_SHORTCUT_MAGNIFICATION,
|
||||
DialogType.EDIT_SHORTCUT_GENERIC,
|
||||
DialogType.EDIT_SHORTCUT_MAGNIFICATION,
|
||||
DialogType.EDIT_MAGNIFICATION_MODE,
|
||||
})
|
||||
|
||||
private @interface DialogType {
|
||||
int EDIT_SHORTCUT_GENERIC = 0;
|
||||
int EDIT_SHORTCUT_MAGNIFICATION = 1;
|
||||
int EDIT_MAGNIFICATION_MODE = 2;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -96,6 +99,23 @@ public class AccessibilityEditDialogUtils {
|
||||
return alertDialog;
|
||||
}
|
||||
|
||||
/**
|
||||
* Method to show the magnification mode dialog in Magnification.
|
||||
*
|
||||
* @param context A valid context
|
||||
* @param dialogTitle The title of magnify mode dialog
|
||||
* @param listener The listener to determine the action of magnify mode dialog
|
||||
* @return A magnification mode dialog in Magnification
|
||||
*/
|
||||
public static AlertDialog showMagnificationModeDialog(Context context,
|
||||
CharSequence dialogTitle, DialogInterface.OnClickListener listener) {
|
||||
final AlertDialog alertDialog = createDialog(context,
|
||||
DialogType.EDIT_MAGNIFICATION_MODE, dialogTitle, listener);
|
||||
alertDialog.show();
|
||||
|
||||
return alertDialog;
|
||||
}
|
||||
|
||||
private static AlertDialog createDialog(Context context, int dialogType,
|
||||
CharSequence dialogTitle, DialogInterface.OnClickListener listener) {
|
||||
|
||||
@@ -138,6 +158,12 @@ public class AccessibilityEditDialogUtils {
|
||||
initMagnifyShortcut(context, contentView);
|
||||
initAdvancedWidget(contentView);
|
||||
break;
|
||||
case DialogType.EDIT_MAGNIFICATION_MODE:
|
||||
contentView = inflater.inflate(
|
||||
R.layout.accessibility_edit_magnification_mode, null);
|
||||
initMagnifyFullScreen(context, contentView);
|
||||
initMagnifyWindowScreen(context, contentView);
|
||||
break;
|
||||
default:
|
||||
throw new IllegalArgumentException();
|
||||
}
|
||||
@@ -145,12 +171,37 @@ public class AccessibilityEditDialogUtils {
|
||||
return contentView;
|
||||
}
|
||||
|
||||
private static void initMagnifyFullScreen(Context context, View view) {
|
||||
final View dialogView = view.findViewById(R.id.magnify_full_screen);
|
||||
final String title = context.getString(
|
||||
R.string.accessibility_magnification_area_settings_full_screen);
|
||||
// TODO(b/146019459): Use vector drawable instead of temporal png file to avoid distorted.
|
||||
setupShortcutWidget(dialogView, title, R.drawable.accessibility_magnification_full_screen);
|
||||
}
|
||||
|
||||
private static void initMagnifyWindowScreen(Context context, View view) {
|
||||
final View dialogView = view.findViewById(R.id.magnify_window_screen);
|
||||
final String title = context.getString(
|
||||
R.string.accessibility_magnification_area_settings_window_screen);
|
||||
// TODO(b/146019459): Use vector drawable instead of temporal png file to avoid distorted.
|
||||
setupShortcutWidget(dialogView, title,
|
||||
R.drawable.accessibility_magnification_window_screen);
|
||||
}
|
||||
|
||||
private static void setupShortcutWidget(View view, CharSequence titleText, int imageResId) {
|
||||
setupShortcutWidget(view, titleText, null, imageResId);
|
||||
}
|
||||
|
||||
private static void setupShortcutWidget(View view, CharSequence titleText,
|
||||
CharSequence summaryText, int imageResId) {
|
||||
final CheckBox checkBox = view.findViewById(R.id.checkbox);
|
||||
checkBox.setText(titleText);
|
||||
final TextView summary = view.findViewById(R.id.summary);
|
||||
summary.setText(summaryText);
|
||||
if (TextUtils.isEmpty(summaryText)) {
|
||||
summary.setVisibility(View.GONE);
|
||||
} else {
|
||||
summary.setText(summaryText);
|
||||
}
|
||||
final ImageView image = view.findViewById(R.id.image);
|
||||
image.setImageResource(imageResId);
|
||||
}
|
||||
|
@@ -42,15 +42,15 @@ public class DaltonizerPreferenceController extends BasePreferenceController {
|
||||
|
||||
@Override
|
||||
public CharSequence getSummary() {
|
||||
final String[] daltonizerSummarys = mContext.getResources().getStringArray(
|
||||
R.array.daltonizer_mode_summary);
|
||||
final String[] daltonizerSummaries = mContext.getResources().getStringArray(
|
||||
R.array.daltonizer_mode_summaries);
|
||||
final int[] daltonizerValues = mContext.getResources().getIntArray(
|
||||
R.array.daltonizer_type_values);
|
||||
final int timeoutValue =
|
||||
DaltonizerRadioButtonPreferenceController.getSecureAccessibilityDaltonizerValue(
|
||||
mContext.getContentResolver(), DALTONIZER_TYPE);
|
||||
final int idx = Ints.indexOf(daltonizerValues, timeoutValue);
|
||||
final String serviceSummary = daltonizerSummarys[idx == -1 ? 0 : idx];
|
||||
final String serviceSummary = daltonizerSummaries[idx == -1 ? 0 : idx];
|
||||
|
||||
final CharSequence serviceState = AccessibilityUtil.getSummary(mContext,
|
||||
DALTONIZER_ENABLED);
|
||||
|
@@ -0,0 +1,41 @@
|
||||
/*
|
||||
* 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 com.android.settings.core.BasePreferenceController;
|
||||
|
||||
/** Controller that shows the magnification area mode summary. */
|
||||
public class MagnificationModePreferenceController extends BasePreferenceController {
|
||||
|
||||
public MagnificationModePreferenceController(Context context, String preferenceKey) {
|
||||
super(context, preferenceKey);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getAvailabilityStatus() {
|
||||
return AVAILABLE;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public CharSequence getSummary() {
|
||||
return MagnificationSettingsFragment.getMagnificationCapabilitiesSummary(
|
||||
mContext);
|
||||
}
|
||||
}
|
@@ -0,0 +1,234 @@
|
||||
/*
|
||||
* 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.app.Dialog;
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.content.Context;
|
||||
import android.content.DialogInterface;
|
||||
import android.os.Bundle;
|
||||
import android.provider.Settings;
|
||||
import android.view.View;
|
||||
import android.widget.CheckBox;
|
||||
|
||||
import androidx.annotation.IntDef;
|
||||
import androidx.appcompat.app.AlertDialog;
|
||||
import androidx.preference.Preference;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.dashboard.DashboardFragment;
|
||||
import com.android.settings.search.BaseSearchIndexProvider;
|
||||
import com.android.settingslib.search.SearchIndexable;
|
||||
|
||||
import com.google.common.primitives.Ints;
|
||||
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
/** Settings page for magnification. */
|
||||
@SearchIndexable
|
||||
public class MagnificationSettingsFragment extends DashboardFragment {
|
||||
|
||||
private static final String TAG = "MagnificationSettingsFragment";
|
||||
private static final String PREF_KEY_MODE = "magnification_mode";
|
||||
// TODO(b/146019459): Use magnification_capability.
|
||||
private static final String KEY_CAPABILITY = Settings.System.MASTER_MONO;
|
||||
private static final int DIALOG_MAGNIFICATION_CAPABILITY = 1;
|
||||
private static final String EXTRA_CAPABILITY = "capability";
|
||||
private Preference mModePreference;
|
||||
private int mCapabilities = MagnifyMode.NONE;
|
||||
private CheckBox mMagnifyFullScreenCheckBox;
|
||||
private CheckBox mMagnifyWindowCheckBox;
|
||||
|
||||
static String getMagnificationCapabilitiesSummary(Context context) {
|
||||
final String[] magnificationModeSummaries = context.getResources().getStringArray(
|
||||
R.array.magnification_mode_summaries);
|
||||
final int[] magnificationModeValues = context.getResources().getIntArray(
|
||||
R.array.magnification_mode_values);
|
||||
final int capabilities = MagnificationSettingsFragment.getMagnificationCapabilities(
|
||||
context);
|
||||
|
||||
final int idx = Ints.indexOf(magnificationModeValues, capabilities);
|
||||
return magnificationModeSummaries[idx == -1 ? 0 : idx];
|
||||
}
|
||||
|
||||
private static int getMagnificationCapabilities(Context context) {
|
||||
return getSecureIntValue(context, KEY_CAPABILITY, MagnifyMode.FULLSCREEN);
|
||||
}
|
||||
|
||||
private static int getSecureIntValue(Context context, String key, int defaultValue) {
|
||||
return Settings.Secure.getIntForUser(
|
||||
context.getContentResolver(),
|
||||
key, defaultValue, context.getContentResolver().getUserId());
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getMetricsCategory() {
|
||||
return SettingsEnums.ACCESSIBILITY_MAGNIFICATION_SETTINGS;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSaveInstanceState(Bundle outState) {
|
||||
outState.putInt(EXTRA_CAPABILITY, mCapabilities);
|
||||
super.onSaveInstanceState(outState);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onActivityCreated(Bundle savedInstanceState) {
|
||||
super.onActivityCreated(savedInstanceState);
|
||||
if (savedInstanceState != null) {
|
||||
mCapabilities = savedInstanceState.getInt(EXTRA_CAPABILITY, MagnifyMode.NONE);
|
||||
}
|
||||
if (mCapabilities == MagnifyMode.NONE) {
|
||||
mCapabilities = getMagnificationCapabilities(getPrefContext());
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getDialogMetricsCategory(int dialogId) {
|
||||
switch (dialogId) {
|
||||
case DIALOG_MAGNIFICATION_CAPABILITY:
|
||||
return SettingsEnums.DIALOG_MAGNIFICATION_CAPABILITY;
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected String getLogTag() {
|
||||
return TAG;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onCreate(Bundle icicle) {
|
||||
super.onCreate(icicle);
|
||||
mModePreference = findPreference(PREF_KEY_MODE);
|
||||
mModePreference.setOnPreferenceClickListener(preference -> {
|
||||
mCapabilities = getMagnificationCapabilities(getPrefContext());
|
||||
showDialog(DIALOG_MAGNIFICATION_CAPABILITY);
|
||||
return true;
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
protected int getPreferenceScreenResId() {
|
||||
return R.xml.accessibility_magnification_service_settings;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Dialog onCreateDialog(int dialogId) {
|
||||
if (dialogId == DIALOG_MAGNIFICATION_CAPABILITY) {
|
||||
final String title = getPrefContext().getString(
|
||||
R.string.accessibility_magnification_mode_title);
|
||||
AlertDialog alertDialog = AccessibilityEditDialogUtils
|
||||
.showMagnificationModeDialog(getPrefContext(), title,
|
||||
this::callOnAlertDialogCheckboxClicked);
|
||||
initializeDialogCheckBox(alertDialog);
|
||||
return alertDialog;
|
||||
}
|
||||
throw new IllegalArgumentException("Unsupported dialogId " + dialogId);
|
||||
}
|
||||
|
||||
private void callOnAlertDialogCheckboxClicked(DialogInterface dialog, int which) {
|
||||
updateCapabilities(true);
|
||||
mModePreference.setSummary(
|
||||
getMagnificationCapabilitiesSummary(getPrefContext()));
|
||||
}
|
||||
|
||||
private void initializeDialogCheckBox(AlertDialog dialog) {
|
||||
final View dialogFullScreenView = dialog.findViewById(R.id.magnify_full_screen);
|
||||
mMagnifyFullScreenCheckBox = dialogFullScreenView.findViewById(R.id.checkbox);
|
||||
|
||||
final View dialogWidowView = dialog.findViewById(R.id.magnify_window_screen);
|
||||
mMagnifyWindowCheckBox = dialogWidowView.findViewById(R.id.checkbox);
|
||||
|
||||
updateAlertDialogCheckState();
|
||||
updateAlertDialogEnableState();
|
||||
}
|
||||
|
||||
private void updateAlertDialogCheckState() {
|
||||
updateCheckStatus(mMagnifyWindowCheckBox, MagnifyMode.WINDOW);
|
||||
updateCheckStatus(mMagnifyFullScreenCheckBox, MagnifyMode.FULLSCREEN);
|
||||
|
||||
}
|
||||
|
||||
private void updateCheckStatus(CheckBox checkBox, int mode) {
|
||||
checkBox.setChecked((mode & mCapabilities) != 0);
|
||||
checkBox.setOnClickListener(v -> {
|
||||
updateCapabilities(false);
|
||||
updateAlertDialogEnableState();
|
||||
});
|
||||
}
|
||||
|
||||
private void updateAlertDialogEnableState() {
|
||||
if (mCapabilities != MagnifyMode.ALL) {
|
||||
disableEnabledMagnificationModePreference();
|
||||
} else {
|
||||
enableAllPreference();
|
||||
}
|
||||
}
|
||||
|
||||
private void enableAllPreference() {
|
||||
mMagnifyFullScreenCheckBox.setEnabled(true);
|
||||
mMagnifyWindowCheckBox.setEnabled(true);
|
||||
}
|
||||
|
||||
private void disableEnabledMagnificationModePreference() {
|
||||
if (!mMagnifyFullScreenCheckBox.isChecked()) {
|
||||
mMagnifyWindowCheckBox.setEnabled(false);
|
||||
} else if (!mMagnifyWindowCheckBox.isChecked()) {
|
||||
mMagnifyFullScreenCheckBox.setEnabled(false);
|
||||
}
|
||||
}
|
||||
|
||||
private void updateCapabilities(boolean saveToDB) {
|
||||
int capabilities = 0;
|
||||
capabilities |=
|
||||
mMagnifyFullScreenCheckBox.isChecked() ? MagnifyMode.FULLSCREEN : 0;
|
||||
capabilities |= mMagnifyWindowCheckBox.isChecked() ? MagnifyMode.WINDOW : 0;
|
||||
mCapabilities = capabilities;
|
||||
if (saveToDB) {
|
||||
setMagnificationCapabilities(capabilities);
|
||||
}
|
||||
}
|
||||
|
||||
private void setSecureIntValue(String key, int value) {
|
||||
Settings.Secure.putIntForUser(getPrefContext().getContentResolver(),
|
||||
key, value, getPrefContext().getContentResolver().getUserId());
|
||||
}
|
||||
|
||||
private void setMagnificationCapabilities(int 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 =
|
||||
new BaseSearchIndexProvider(R.xml.accessibility_magnification_service_settings);
|
||||
}
|
@@ -0,0 +1,60 @@
|
||||
/*
|
||||
* 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;
|
||||
}
|
||||
}
|
@@ -54,6 +54,7 @@ import com.android.settings.widget.SwitchBar;
|
||||
public class ToggleScreenMagnificationPreferenceFragment extends
|
||||
ToggleFeaturePreferenceFragment implements SwitchBar.OnSwitchChangeListener {
|
||||
|
||||
private static final String SETTINGS_KEY = "screen_magnification_settings";
|
||||
private static final int DIALOG_ID_GESTURE_NAVIGATION_TUTORIAL = 1;
|
||||
private static final int DIALOG_ID_ACCESSIBILITY_BUTTON_TUTORIAL = 2;
|
||||
private static final int DIALOG_ID_EDIT_SHORTCUT = 3;
|
||||
@@ -170,6 +171,13 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
||||
mVideoPreference.setPersistent(false);
|
||||
mVideoPreference.setLayoutResource(R.layout.magnification_video_preference);
|
||||
|
||||
final Preference settingsPreference = new Preference(getPrefContext());
|
||||
final String SettingsText = getString(R.string.settings_button);
|
||||
settingsPreference.setTitle(SettingsText);
|
||||
settingsPreference.setKey(SETTINGS_KEY);
|
||||
settingsPreference.setFragment(MagnificationSettingsFragment.class.getName());
|
||||
settingsPreference.setPersistent(false);
|
||||
|
||||
mConfigWarningPreference = new Preference(getPrefContext());
|
||||
mConfigWarningPreference.setSelectable(false);
|
||||
mConfigWarningPreference.setPersistent(false);
|
||||
@@ -179,8 +187,10 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
||||
final PreferenceScreen preferenceScreen = getPreferenceManager().getPreferenceScreen();
|
||||
preferenceScreen.setOrderingAsAdded(false);
|
||||
mVideoPreference.setOrder(0);
|
||||
settingsPreference.setOrder(1);
|
||||
mConfigWarningPreference.setOrder(2);
|
||||
preferenceScreen.addPreference(mVideoPreference);
|
||||
preferenceScreen.addPreference(settingsPreference);
|
||||
preferenceScreen.addPreference(mConfigWarningPreference);
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user