Refactoring A11y shortcut functions in Settings to use GESTURE
Properly integrating GESTURE into Settings, so that text pertaining to the gesture shortcut are displayed when appropriate. Heavy refactoring has been done to allow for easier cleanup and expansion Demo video: https://x20web.corp.google.com/users/jo/jonesriley/splitShortcut/a11ySettingsGestureCompat.mp4 NO_IFTTT=changes do not alter the order of the shortcuts. Bug: 365570709 Test: atest com.android.settings.accessibility Flag: android.provider.a11y_standalone_gesture_enabled Change-Id: If90719763a48e3b8bc35988a1de9a352a766953b
This commit is contained in:
@@ -49,9 +49,14 @@ public class AccessibilityButtonFooterPreferenceController extends
|
|||||||
public void displayPreference(PreferenceScreen screen) {
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
// Need to update footerPreference's data before super.displayPreference(), then it will use
|
// Need to update footerPreference's data before super.displayPreference(), then it will use
|
||||||
// data to update related property of footerPreference.
|
// data to update related property of footerPreference.
|
||||||
final int titleResource = AccessibilityUtil.isGestureNavigateEnabled(mContext)
|
final int titleResource;
|
||||||
? R.string.accessibility_button_gesture_description
|
if (android.provider.Flags.a11yStandaloneGestureEnabled()) {
|
||||||
: R.string.accessibility_button_description;
|
titleResource = R.string.accessibility_button_description;
|
||||||
|
} else {
|
||||||
|
titleResource = AccessibilityUtil.isGestureNavigateEnabled(mContext)
|
||||||
|
? R.string.accessibility_button_gesture_description
|
||||||
|
: R.string.accessibility_button_description;
|
||||||
|
}
|
||||||
final CharSequence footerText = Html.fromHtml(
|
final CharSequence footerText = Html.fromHtml(
|
||||||
MessageFormat.format(mContext.getString(titleResource), 1, 2, 3),
|
MessageFormat.format(mContext.getString(titleResource), 1, 2, 3),
|
||||||
Html.FROM_HTML_MODE_COMPACT);
|
Html.FROM_HTML_MODE_COMPACT);
|
||||||
|
@@ -61,7 +61,12 @@ public class AccessibilityButtonPreferenceController extends BasePreferenceContr
|
|||||||
}
|
}
|
||||||
|
|
||||||
private int getPreferenceTitleResource() {
|
private int getPreferenceTitleResource() {
|
||||||
return AccessibilityUtil.isGestureNavigateEnabled(mContext)
|
if (android.provider.Flags.a11yStandaloneGestureEnabled()) {
|
||||||
? R.string.accessibility_button_gesture_title : R.string.accessibility_button_title;
|
return R.string.accessibility_button_title;
|
||||||
|
} else {
|
||||||
|
return AccessibilityUtil.isGestureNavigateEnabled(mContext)
|
||||||
|
? R.string.accessibility_button_gesture_title
|
||||||
|
: R.string.accessibility_button_title;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -17,10 +17,8 @@
|
|||||||
package com.android.settings.accessibility;
|
package com.android.settings.accessibility;
|
||||||
|
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.DEFAULT;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.DEFAULT;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
|
||||||
import static com.android.settings.accessibility.AccessibilityDialogUtils.DialogEnums;
|
import static com.android.settings.accessibility.AccessibilityDialogUtils.DialogEnums;
|
||||||
|
import static com.android.settings.accessibility.AccessibilityUtil.getShortcutSummaryList;
|
||||||
import static com.android.settings.accessibility.ToggleFeaturePreferenceFragment.KEY_GENERAL_CATEGORY;
|
import static com.android.settings.accessibility.ToggleFeaturePreferenceFragment.KEY_GENERAL_CATEGORY;
|
||||||
import static com.android.settings.accessibility.ToggleFeaturePreferenceFragment.KEY_SAVED_QS_TOOLTIP_TYPE;
|
import static com.android.settings.accessibility.ToggleFeaturePreferenceFragment.KEY_SAVED_QS_TOOLTIP_TYPE;
|
||||||
|
|
||||||
@@ -30,7 +28,6 @@ import android.app.settings.SettingsEnums;
|
|||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.icu.text.CaseMap;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
@@ -46,18 +43,15 @@ import androidx.preference.PreferenceCategory;
|
|||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.internal.accessibility.common.ShortcutConstants;
|
import com.android.internal.accessibility.common.ShortcutConstants;
|
||||||
import com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType;
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
||||||
import com.android.settings.accessibility.shortcuts.EditShortcutsPreferenceFragment;
|
import com.android.settings.accessibility.shortcuts.EditShortcutsPreferenceFragment;
|
||||||
import com.android.settings.dashboard.RestrictedDashboardFragment;
|
import com.android.settings.dashboard.RestrictedDashboardFragment;
|
||||||
import com.android.settings.utils.LocaleUtils;
|
|
||||||
|
|
||||||
import com.google.android.setupcompat.util.WizardManagerHelper;
|
import com.google.android.setupcompat.util.WizardManagerHelper;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Base class for accessibility fragments shortcut functions and dialog management.
|
* Base class for accessibility fragments shortcut functions and dialog management.
|
||||||
@@ -340,37 +334,7 @@ public abstract class AccessibilityShortcutPreferenceFragment extends Restricted
|
|||||||
}
|
}
|
||||||
|
|
||||||
final int shortcutTypes = getUserPreferredShortcutTypes();
|
final int shortcutTypes = getUserPreferredShortcutTypes();
|
||||||
|
return getShortcutSummaryList(context, shortcutTypes);
|
||||||
// LINT.IfChange(shortcut_type_ui_order)
|
|
||||||
final List<CharSequence> list = new ArrayList<>();
|
|
||||||
if (android.view.accessibility.Flags.a11yQsShortcut()) {
|
|
||||||
if (hasShortcutType(shortcutTypes, QUICK_SETTINGS)) {
|
|
||||||
final CharSequence qsTitle = context.getText(
|
|
||||||
R.string.accessibility_feature_shortcut_setting_summary_quick_settings);
|
|
||||||
list.add(qsTitle);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (hasShortcutType(shortcutTypes, SOFTWARE)) {
|
|
||||||
list.add(getSoftwareShortcutTypeSummary(context));
|
|
||||||
}
|
|
||||||
if (hasShortcutType(shortcutTypes, HARDWARE)) {
|
|
||||||
final CharSequence hardwareTitle = context.getText(
|
|
||||||
R.string.accessibility_shortcut_hardware_keyword);
|
|
||||||
list.add(hardwareTitle);
|
|
||||||
}
|
|
||||||
// LINT.ThenChange(/res/xml/accessibility_edit_shortcuts.xml:shortcut_type_ui_order)
|
|
||||||
|
|
||||||
// Show software shortcut if first time to use.
|
|
||||||
if (list.isEmpty()) {
|
|
||||||
list.add(getSoftwareShortcutTypeSummary(context));
|
|
||||||
}
|
|
||||||
|
|
||||||
return CaseMap.toTitle().wholeString().noLowercase().apply(Locale.getDefault(), /* iter= */
|
|
||||||
null, LocaleUtils.getConcatenatedString(list));
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean hasShortcutType(int value, @UserShortcutType int type) {
|
|
||||||
return (value & type) == type;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void updateShortcutPreferenceData() {
|
protected void updateShortcutPreferenceData() {
|
||||||
|
@@ -16,15 +16,19 @@
|
|||||||
|
|
||||||
package com.android.settings.accessibility;
|
package com.android.settings.accessibility;
|
||||||
|
|
||||||
|
import static android.provider.Settings.Secure.ACCESSIBILITY_BUTTON_MODE_FLOATING_MENU;
|
||||||
|
import static android.provider.Settings.Secure.ACCESSIBILITY_BUTTON_MODE_GESTURE;
|
||||||
import static android.view.View.GONE;
|
import static android.view.View.GONE;
|
||||||
import static android.view.View.VISIBLE;
|
import static android.view.View.VISIBLE;
|
||||||
|
|
||||||
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.GESTURE;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.TRIPLETAP;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.TRIPLETAP;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.TWOFINGER_DOUBLETAP;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.TWOFINGER_DOUBLETAP;
|
||||||
|
|
||||||
|
import android.annotation.SuppressLint;
|
||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
@@ -60,7 +64,9 @@ import androidx.core.widget.TextViewCompat;
|
|||||||
import androidx.viewpager.widget.PagerAdapter;
|
import androidx.viewpager.widget.PagerAdapter;
|
||||||
import androidx.viewpager.widget.ViewPager;
|
import androidx.viewpager.widget.ViewPager;
|
||||||
|
|
||||||
import com.android.server.accessibility.Flags;
|
import com.android.internal.accessibility.common.ShortcutConstants;
|
||||||
|
import com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType;
|
||||||
|
import com.android.internal.accessibility.util.ShortcutUtils;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.SubSettingLauncher;
|
import com.android.settings.core.SubSettingLauncher;
|
||||||
import com.android.settingslib.utils.StringUtil;
|
import com.android.settingslib.utils.StringUtil;
|
||||||
@@ -396,95 +402,84 @@ public final class AccessibilityShortcutsTutorial {
|
|||||||
return textView;
|
return textView;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TutorialPage createSoftwareTutorialPage(@NonNull Context context) {
|
@SuppressLint("SwitchIntDef")
|
||||||
final int type = SOFTWARE;
|
private static CharSequence getShortcutTitle(
|
||||||
final CharSequence title = getSoftwareTitle(context);
|
@NonNull Context context, @UserShortcutType int shortcutType, int buttonMode) {
|
||||||
final View image = createSoftwareImage(context);
|
return switch (shortcutType) {
|
||||||
final CharSequence instruction = getSoftwareInstruction(context);
|
case HARDWARE -> context.getText(R.string.accessibility_tutorial_dialog_title_volume);
|
||||||
final ImageView indicatorIcon =
|
case SOFTWARE -> getSoftwareTitle(context, buttonMode);
|
||||||
createImageView(context, R.drawable.ic_accessibility_page_indicator);
|
case GESTURE -> context.getText(R.string.accessibility_tutorial_dialog_title_gesture);
|
||||||
indicatorIcon.setEnabled(false);
|
case TRIPLETAP -> context.getText(R.string.accessibility_tutorial_dialog_title_triple);
|
||||||
|
case TWOFINGER_DOUBLETAP -> context.getString(
|
||||||
return new TutorialPage(type, title, image, indicatorIcon, instruction);
|
R.string.accessibility_tutorial_dialog_title_two_finger_double, 2);
|
||||||
|
case QUICK_SETTINGS -> context.getText(
|
||||||
|
R.string.accessibility_tutorial_dialog_title_quick_setting);
|
||||||
|
default -> "";
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TutorialPage createHardwareTutorialPage(@NonNull Context context) {
|
@SuppressLint("SwitchIntDef")
|
||||||
final int type = HARDWARE;
|
private static View getShortcutImage(
|
||||||
final CharSequence title =
|
@NonNull Context context, @UserShortcutType int shortcutType, int buttonMode) {
|
||||||
context.getText(R.string.accessibility_tutorial_dialog_title_volume);
|
return switch (shortcutType) {
|
||||||
final View image =
|
case HARDWARE -> createIllustrationView(
|
||||||
createIllustrationView(context, R.drawable.accessibility_shortcut_type_volume_keys);
|
context, R.drawable.accessibility_shortcut_type_volume_keys);
|
||||||
final ImageView indicatorIcon =
|
case SOFTWARE -> createSoftwareImage(context, buttonMode);
|
||||||
createImageView(context, R.drawable.ic_accessibility_page_indicator);
|
case GESTURE -> createIllustrationView(context,
|
||||||
final CharSequence instruction =
|
AccessibilityUtil.isTouchExploreEnabled(context)
|
||||||
context.getText(R.string.accessibility_tutorial_dialog_message_volume);
|
? R.drawable.accessibility_shortcut_type_gesture_touch_explore_on
|
||||||
indicatorIcon.setEnabled(false);
|
: R.drawable.accessibility_shortcut_type_gesture);
|
||||||
|
case TRIPLETAP -> createIllustrationViewWithImageRawResource(context,
|
||||||
return new TutorialPage(type, title, image, indicatorIcon, instruction);
|
R.raw.accessibility_shortcut_type_tripletap);
|
||||||
}
|
case TWOFINGER_DOUBLETAP -> createIllustrationViewWithImageRawResource(context,
|
||||||
|
R.raw.accessibility_shortcut_type_2finger_doubletap);
|
||||||
private static TutorialPage createTripleTapTutorialPage(@NonNull Context context) {
|
case QUICK_SETTINGS -> {
|
||||||
final int type = TRIPLETAP;
|
View v = createIllustrationView(context,
|
||||||
final CharSequence title =
|
|
||||||
context.getText(R.string.accessibility_tutorial_dialog_title_triple);
|
|
||||||
final View image =
|
|
||||||
createIllustrationViewWithImageRawResource(context,
|
|
||||||
R.raw.accessibility_shortcut_type_tripletap);
|
|
||||||
final CharSequence instruction = context.getString(
|
|
||||||
R.string.accessibility_tutorial_dialog_tripletap_instruction, 3);
|
|
||||||
final ImageView indicatorIcon =
|
|
||||||
createImageView(context, R.drawable.ic_accessibility_page_indicator);
|
|
||||||
indicatorIcon.setEnabled(false);
|
|
||||||
|
|
||||||
return new TutorialPage(type, title, image, indicatorIcon, instruction);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static TutorialPage createTwoFingerTripleTapTutorialPage(@NonNull Context context) {
|
|
||||||
final int type = TWOFINGER_DOUBLETAP;
|
|
||||||
final int numFingers = 2;
|
|
||||||
final CharSequence title = context.getString(
|
|
||||||
R.string.accessibility_tutorial_dialog_title_two_finger_double, numFingers);
|
|
||||||
final View image =
|
|
||||||
createIllustrationViewWithImageRawResource(context,
|
|
||||||
R.raw.accessibility_shortcut_type_2finger_doubletap);
|
|
||||||
final CharSequence instruction = context.getString(
|
|
||||||
R.string.accessibility_tutorial_dialog_twofinger_doubletap_instruction, numFingers);
|
|
||||||
final ImageView indicatorIcon =
|
|
||||||
createImageView(context, R.drawable.ic_accessibility_page_indicator);
|
|
||||||
indicatorIcon.setEnabled(false);
|
|
||||||
|
|
||||||
return new TutorialPage(type, title, image, indicatorIcon, instruction);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static TutorialPage createQuickSettingsTutorialPage(
|
|
||||||
@NonNull Context context, @NonNull CharSequence featureName, boolean inSetupWizard) {
|
|
||||||
final int type = QUICK_SETTINGS;
|
|
||||||
final CharSequence title =
|
|
||||||
context.getText(R.string.accessibility_tutorial_dialog_title_quick_setting);
|
|
||||||
final View image =
|
|
||||||
createIllustrationView(context,
|
|
||||||
R.drawable.accessibility_shortcut_type_quick_settings);
|
R.drawable.accessibility_shortcut_type_quick_settings);
|
||||||
// Remove the unneeded background, since the main image already includes a background
|
View bg = v.findViewById(R.id.image_background);
|
||||||
image.findViewById(R.id.image_background).setVisibility(GONE);
|
if (bg != null) {
|
||||||
final int numFingers = AccessibilityUtil.isTouchExploreEnabled(context) ? 2 : 1;
|
bg.setVisibility(GONE);
|
||||||
Map<String, Object> arguments = new ArrayMap<>();
|
}
|
||||||
arguments.put("count", numFingers);
|
yield v;
|
||||||
arguments.put("featureName", featureName);
|
}
|
||||||
final CharSequence instruction = StringUtil.getIcuPluralsString(context,
|
default -> new View(context);
|
||||||
arguments,
|
};
|
||||||
R.string.accessibility_tutorial_dialog_message_quick_setting);
|
}
|
||||||
final SpannableStringBuilder tutorialText = new SpannableStringBuilder();
|
|
||||||
if (inSetupWizard) {
|
private static CharSequence getShortcutInstruction(
|
||||||
tutorialText.append(context.getText(
|
@NonNull Context context, @UserShortcutType int shortcutType, int buttonMode,
|
||||||
R.string.accessibility_tutorial_dialog_shortcut_unavailable_in_suw))
|
@NonNull CharSequence featureName, boolean inSetupWizard) {
|
||||||
.append("\n\n");
|
return switch (shortcutType) {
|
||||||
}
|
case HARDWARE -> context.getText(R.string.accessibility_tutorial_dialog_message_volume);
|
||||||
tutorialText.append(instruction);
|
case SOFTWARE -> getSoftwareInstruction(context, buttonMode);
|
||||||
|
case GESTURE -> StringUtil.getIcuPluralsString(
|
||||||
|
context,
|
||||||
|
AccessibilityUtil.isTouchExploreEnabled(context) ? 3 : 2,
|
||||||
|
R.string.accessibility_tutorial_dialog_gesture_shortcut_instruction);
|
||||||
|
case TRIPLETAP -> context.getString(
|
||||||
|
R.string.accessibility_tutorial_dialog_tripletap_instruction, 3);
|
||||||
|
case TWOFINGER_DOUBLETAP -> context.getString(
|
||||||
|
R.string.accessibility_tutorial_dialog_twofinger_doubletap_instruction, 2);
|
||||||
|
case QUICK_SETTINGS -> getQuickSettingsInstruction(context, featureName, inSetupWizard);
|
||||||
|
default -> "";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressLint("SwitchIntDef")
|
||||||
|
private static TutorialPage createShortcutTutorialPage(
|
||||||
|
@NonNull Context context, @UserShortcutType int shortcutType, int buttonMode,
|
||||||
|
@NonNull CharSequence featureName, boolean inSetupWizard) {
|
||||||
|
|
||||||
final ImageView indicatorIcon =
|
final ImageView indicatorIcon =
|
||||||
createImageView(context, R.drawable.ic_accessibility_page_indicator);
|
createImageView(context, R.drawable.ic_accessibility_page_indicator);
|
||||||
indicatorIcon.setEnabled(false);
|
indicatorIcon.setEnabled(false);
|
||||||
|
|
||||||
return new TutorialPage(type, title, image, indicatorIcon, tutorialText);
|
return new TutorialPage(shortcutType,
|
||||||
|
getShortcutTitle(context, shortcutType, buttonMode),
|
||||||
|
getShortcutImage(context, shortcutType, buttonMode),
|
||||||
|
createImageView(context, R.drawable.ic_accessibility_page_indicator),
|
||||||
|
getShortcutInstruction(
|
||||||
|
context, shortcutType, buttonMode, featureName, inSetupWizard));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -497,79 +492,58 @@ public final class AccessibilityShortcutsTutorial {
|
|||||||
boolean inSetupWizard) {
|
boolean inSetupWizard) {
|
||||||
// LINT.IfChange(shortcut_type_ui_order)
|
// LINT.IfChange(shortcut_type_ui_order)
|
||||||
final List<TutorialPage> tutorialPages = new ArrayList<>();
|
final List<TutorialPage> tutorialPages = new ArrayList<>();
|
||||||
if (android.view.accessibility.Flags.a11yQsShortcut()) {
|
int buttonMode = ShortcutUtils.getButtonMode(context, context.getUserId());
|
||||||
if ((shortcutTypes & QUICK_SETTINGS)
|
|
||||||
== QUICK_SETTINGS) {
|
for (int shortcutType: ShortcutConstants.USER_SHORTCUT_TYPES) {
|
||||||
tutorialPages.add(
|
if ((shortcutTypes & shortcutType) == 0) {
|
||||||
createQuickSettingsTutorialPage(context, featureName, inSetupWizard));
|
continue;
|
||||||
}
|
}
|
||||||
}
|
if ((shortcutTypes & QUICK_SETTINGS) == QUICK_SETTINGS
|
||||||
if ((shortcutTypes & SOFTWARE) == SOFTWARE) {
|
&& !android.view.accessibility.Flags.a11yQsShortcut()) {
|
||||||
tutorialPages.add(createSoftwareTutorialPage(context));
|
continue;
|
||||||
}
|
|
||||||
|
|
||||||
if ((shortcutTypes & HARDWARE) == HARDWARE) {
|
|
||||||
tutorialPages.add(createHardwareTutorialPage(context));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (Flags.enableMagnificationMultipleFingerMultipleTapGesture()) {
|
|
||||||
if ((shortcutTypes & TWOFINGER_DOUBLETAP)
|
|
||||||
== TWOFINGER_DOUBLETAP) {
|
|
||||||
tutorialPages.add(createTwoFingerTripleTapTutorialPage(context));
|
|
||||||
}
|
}
|
||||||
}
|
tutorialPages.add(
|
||||||
|
createShortcutTutorialPage(
|
||||||
if ((shortcutTypes & TRIPLETAP) == TRIPLETAP) {
|
context, shortcutType, buttonMode, featureName, inSetupWizard));
|
||||||
tutorialPages.add(createTripleTapTutorialPage(context));
|
|
||||||
}
|
}
|
||||||
// LINT.ThenChange(/res/xml/accessibility_edit_shortcuts.xml:shortcut_type_ui_order)
|
// LINT.ThenChange(/res/xml/accessibility_edit_shortcuts.xml:shortcut_type_ui_order)
|
||||||
|
|
||||||
return tutorialPages;
|
return tutorialPages;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static View createSoftwareImage(Context context) {
|
private static View createSoftwareImage(Context context, int buttonMode) {
|
||||||
int resId;
|
return switch(buttonMode) {
|
||||||
if (AccessibilityUtil.isFloatingMenuEnabled(context)) {
|
case ACCESSIBILITY_BUTTON_MODE_GESTURE ->
|
||||||
return createIllustrationViewWithImageRawResource(
|
createIllustrationView(context,
|
||||||
context, R.raw.accessibility_shortcut_type_fab);
|
AccessibilityUtil.isTouchExploreEnabled(context)
|
||||||
} else if (AccessibilityUtil.isGestureNavigateEnabled(context)) {
|
? R.drawable
|
||||||
resId = AccessibilityUtil.isTouchExploreEnabled(context)
|
.accessibility_shortcut_type_gesture_touch_explore_on
|
||||||
? R.drawable.accessibility_shortcut_type_gesture_touch_explore_on
|
: R.drawable.accessibility_shortcut_type_gesture);
|
||||||
: R.drawable.accessibility_shortcut_type_gesture;
|
case ACCESSIBILITY_BUTTON_MODE_FLOATING_MENU ->
|
||||||
} else {
|
createIllustrationViewWithImageRawResource(
|
||||||
resId = R.drawable.accessibility_shortcut_type_navbar;
|
context, R.raw.accessibility_shortcut_type_fab);
|
||||||
}
|
default -> createIllustrationView(
|
||||||
return createIllustrationView(context, resId);
|
context, R.drawable.accessibility_shortcut_type_navbar);
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
private static CharSequence getSoftwareTitle(Context context) {
|
private static CharSequence getSoftwareTitle(Context context, int buttonMode) {
|
||||||
int resId;
|
return context.getText(buttonMode == ACCESSIBILITY_BUTTON_MODE_GESTURE
|
||||||
if (AccessibilityUtil.isFloatingMenuEnabled(context)) {
|
? R.string.accessibility_tutorial_dialog_title_gesture
|
||||||
resId = R.string.accessibility_tutorial_dialog_title_button;
|
: R.string.accessibility_tutorial_dialog_title_button);
|
||||||
} else if (AccessibilityUtil.isGestureNavigateEnabled(context)) {
|
|
||||||
resId = R.string.accessibility_tutorial_dialog_title_gesture;
|
|
||||||
} else {
|
|
||||||
resId = R.string.accessibility_tutorial_dialog_title_button;
|
|
||||||
}
|
|
||||||
return context.getText(resId);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static CharSequence getSoftwareInstruction(Context context) {
|
private static CharSequence getSoftwareInstruction(Context context, int buttonMode) {
|
||||||
final SpannableStringBuilder sb = new SpannableStringBuilder();
|
return switch(buttonMode) {
|
||||||
if (AccessibilityUtil.isFloatingMenuEnabled(context)) {
|
case ACCESSIBILITY_BUTTON_MODE_FLOATING_MENU -> context.getText(
|
||||||
final int resId = R.string.accessibility_tutorial_dialog_message_floating_button;
|
R.string.accessibility_tutorial_dialog_message_floating_button);
|
||||||
sb.append(context.getText(resId));
|
case ACCESSIBILITY_BUTTON_MODE_GESTURE -> StringUtil.getIcuPluralsString(
|
||||||
} else if (AccessibilityUtil.isGestureNavigateEnabled(context)) {
|
|
||||||
final int numFingers = AccessibilityUtil.isTouchExploreEnabled(context) ? 3 : 2;
|
|
||||||
sb.append(StringUtil.getIcuPluralsString(
|
|
||||||
context,
|
context,
|
||||||
numFingers,
|
AccessibilityUtil.isTouchExploreEnabled(context) ? 3 : 2,
|
||||||
R.string.accessibility_tutorial_dialog_gesture_shortcut_instruction));
|
R.string.accessibility_tutorial_dialog_gesture_shortcut_instruction);
|
||||||
} else {
|
default -> getSoftwareInstructionWithIcon(context,
|
||||||
final int resId = R.string.accessibility_tutorial_dialog_message_button;
|
context.getText(R.string.accessibility_tutorial_dialog_message_button));
|
||||||
sb.append(getSoftwareInstructionWithIcon(context, context.getText(resId)));
|
};
|
||||||
}
|
|
||||||
return sb;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static CharSequence getSoftwareInstructionWithIcon(Context context, CharSequence text) {
|
private static CharSequence getSoftwareInstructionWithIcon(Context context, CharSequence text) {
|
||||||
@@ -590,6 +564,24 @@ public final class AccessibilityShortcutsTutorial {
|
|||||||
return spannableInstruction;
|
return spannableInstruction;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static CharSequence getQuickSettingsInstruction(
|
||||||
|
Context context, CharSequence featureName, boolean inSetupWizard) {
|
||||||
|
Map<String, Object> arguments = new ArrayMap<>();
|
||||||
|
arguments.put("count",
|
||||||
|
AccessibilityUtil.isTouchExploreEnabled(context) ? 2 : 1);
|
||||||
|
arguments.put("featureName", featureName);
|
||||||
|
final CharSequence pluralsString = StringUtil.getIcuPluralsString(
|
||||||
|
context, arguments,
|
||||||
|
R.string.accessibility_tutorial_dialog_message_quick_setting);
|
||||||
|
final SpannableStringBuilder tutorialText = new SpannableStringBuilder();
|
||||||
|
if (inSetupWizard) {
|
||||||
|
tutorialText.append(context.getText(R.string
|
||||||
|
.accessibility_tutorial_dialog_shortcut_unavailable_in_suw))
|
||||||
|
.append("\n\n");
|
||||||
|
}
|
||||||
|
return tutorialText.append(pluralsString);
|
||||||
|
}
|
||||||
|
|
||||||
private static class TutorialPage {
|
private static class TutorialPage {
|
||||||
private final int mType;
|
private final int mType;
|
||||||
private final CharSequence mTitle;
|
private final CharSequence mTitle;
|
||||||
|
@@ -22,10 +22,12 @@ import static android.view.WindowInsets.Type.systemBars;
|
|||||||
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_GESTURAL;
|
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_GESTURAL;
|
||||||
|
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.DEFAULT;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.DEFAULT;
|
||||||
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.GESTURE;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.TRIPLETAP;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.TRIPLETAP;
|
||||||
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.TWOFINGER_DOUBLETAP;
|
||||||
|
|
||||||
import android.accessibilityservice.AccessibilityServiceInfo;
|
import android.accessibilityservice.AccessibilityServiceInfo;
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
@@ -33,6 +35,7 @@ import android.content.Context;
|
|||||||
import android.content.res.Resources;
|
import android.content.res.Resources;
|
||||||
import android.graphics.Insets;
|
import android.graphics.Insets;
|
||||||
import android.graphics.Rect;
|
import android.graphics.Rect;
|
||||||
|
import android.icu.text.CaseMap;
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
@@ -47,11 +50,17 @@ import androidx.annotation.NonNull;
|
|||||||
import androidx.annotation.StringRes;
|
import androidx.annotation.StringRes;
|
||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
|
|
||||||
|
import com.android.internal.accessibility.common.ShortcutConstants;
|
||||||
import com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType;
|
import com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType;
|
||||||
import com.android.internal.accessibility.util.ShortcutUtils;
|
import com.android.internal.accessibility.util.ShortcutUtils;
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.utils.LocaleUtils;
|
||||||
|
|
||||||
import java.lang.annotation.Retention;
|
import java.lang.annotation.Retention;
|
||||||
import java.lang.annotation.RetentionPolicy;
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Locale;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.StringJoiner;
|
import java.util.StringJoiner;
|
||||||
|
|
||||||
@@ -139,8 +148,8 @@ public final class AccessibilityUtil {
|
|||||||
|
|
||||||
/** Determines if a gesture navigation bar is being used. */
|
/** Determines if a gesture navigation bar is being used. */
|
||||||
public static boolean isGestureNavigateEnabled(Context context) {
|
public static boolean isGestureNavigateEnabled(Context context) {
|
||||||
return context.getResources().getInteger(
|
return Settings.Secure.getInt(context.getContentResolver(),
|
||||||
com.android.internal.R.integer.config_navBarInteractionMode)
|
Settings.Secure.NAVIGATION_MODE, -1)
|
||||||
== NAV_BAR_MODE_GESTURAL;
|
== NAV_BAR_MODE_GESTURAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -335,22 +344,23 @@ public final class AccessibilityUtil {
|
|||||||
*/
|
*/
|
||||||
static boolean hasValuesInSettings(Context context, int shortcutTypes,
|
static boolean hasValuesInSettings(Context context, int shortcutTypes,
|
||||||
@NonNull ComponentName componentName) {
|
@NonNull ComponentName componentName) {
|
||||||
boolean exist = false;
|
for (int shortcutType : ShortcutConstants.USER_SHORTCUT_TYPES) {
|
||||||
if ((shortcutTypes & SOFTWARE) == SOFTWARE) {
|
if (!android.view.accessibility.Flags.a11yQsShortcut()) {
|
||||||
exist = hasValueInSettings(context, SOFTWARE, componentName);
|
if ((shortcutType & QUICK_SETTINGS) == QUICK_SETTINGS) {
|
||||||
}
|
continue;
|
||||||
if (((shortcutTypes & HARDWARE) == HARDWARE)) {
|
}
|
||||||
exist |= hasValueInSettings(context, HARDWARE, componentName);
|
}
|
||||||
}
|
if (!android.provider.Flags.a11yStandaloneGestureEnabled()) {
|
||||||
if (android.view.accessibility.Flags.a11yQsShortcut()) {
|
if ((shortcutType & GESTURE) == GESTURE) {
|
||||||
if ((shortcutTypes & QUICK_SETTINGS)
|
continue;
|
||||||
== QUICK_SETTINGS) {
|
}
|
||||||
exist |= hasValueInSettings(context, QUICK_SETTINGS,
|
}
|
||||||
componentName);
|
if ((shortcutTypes & shortcutType) == shortcutType
|
||||||
|
&& hasValueInSettings(context, shortcutType, componentName)) {
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return false;
|
||||||
return exist;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -364,29 +374,14 @@ public final class AccessibilityUtil {
|
|||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
static boolean hasValueInSettings(Context context, @UserShortcutType int shortcutType,
|
static boolean hasValueInSettings(Context context, @UserShortcutType int shortcutType,
|
||||||
@NonNull ComponentName componentName) {
|
@NonNull ComponentName componentName) {
|
||||||
if (android.view.accessibility.Flags.a11yQsShortcut()) {
|
if (!android.view.accessibility.Flags.a11yQsShortcut()
|
||||||
return ShortcutUtils.getShortcutTargetsFromSettings(
|
&& (shortcutType & QUICK_SETTINGS) == QUICK_SETTINGS) {
|
||||||
context, shortcutType, UserHandle.myUserId()
|
|
||||||
).contains(componentName.flattenToString());
|
|
||||||
}
|
|
||||||
|
|
||||||
final String targetKey = convertKeyFromSettings(shortcutType);
|
|
||||||
final String targetString = Settings.Secure.getString(context.getContentResolver(),
|
|
||||||
targetKey);
|
|
||||||
|
|
||||||
if (TextUtils.isEmpty(targetString)) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
sStringColonSplitter.setString(targetString);
|
return ShortcutUtils.getShortcutTargetsFromSettings(
|
||||||
|
context, shortcutType, UserHandle.myUserId()
|
||||||
while (sStringColonSplitter.hasNext()) {
|
).contains(componentName.flattenToString());
|
||||||
final String name = sStringColonSplitter.next();
|
|
||||||
if ((componentName.flattenToString()).equals(name)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -400,15 +395,19 @@ public final class AccessibilityUtil {
|
|||||||
static int getUserShortcutTypesFromSettings(Context context,
|
static int getUserShortcutTypesFromSettings(Context context,
|
||||||
@NonNull ComponentName componentName) {
|
@NonNull ComponentName componentName) {
|
||||||
int shortcutTypes = DEFAULT;
|
int shortcutTypes = DEFAULT;
|
||||||
if (hasValuesInSettings(context, SOFTWARE, componentName)) {
|
for (int shortcutType : ShortcutConstants.USER_SHORTCUT_TYPES) {
|
||||||
shortcutTypes |= SOFTWARE;
|
if (!android.view.accessibility.Flags.a11yQsShortcut()) {
|
||||||
}
|
if ((shortcutType & QUICK_SETTINGS) == QUICK_SETTINGS) {
|
||||||
if (hasValuesInSettings(context, HARDWARE, componentName)) {
|
continue;
|
||||||
shortcutTypes |= HARDWARE;
|
}
|
||||||
}
|
}
|
||||||
if (android.view.accessibility.Flags.a11yQsShortcut()) {
|
if (!android.provider.Flags.a11yStandaloneGestureEnabled()) {
|
||||||
if (hasValuesInSettings(context, QUICK_SETTINGS, componentName)) {
|
if ((shortcutType & GESTURE) == GESTURE) {
|
||||||
shortcutTypes |= QUICK_SETTINGS;
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (hasValueInSettings(context, shortcutType, componentName)) {
|
||||||
|
shortcutTypes |= shortcutType;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -505,4 +504,66 @@ public final class AccessibilityUtil {
|
|||||||
Settings.Secure.SKIP_ACCESSIBILITY_SHORTCUT_DIALOG_TIMEOUT_RESTRICTION, /*
|
Settings.Secure.SKIP_ACCESSIBILITY_SHORTCUT_DIALOG_TIMEOUT_RESTRICTION, /*
|
||||||
true */ 1);
|
true */ 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Assembles a localized string describing the provided shortcut types.
|
||||||
|
*/
|
||||||
|
public static CharSequence getShortcutSummaryList(Context context, int shortcutTypes) {
|
||||||
|
final List<CharSequence> list = new ArrayList<>();
|
||||||
|
|
||||||
|
// LINT.IfChange(shortcut_type_ui_order)
|
||||||
|
for (int shortcutType : ShortcutConstants.USER_SHORTCUT_TYPES) {
|
||||||
|
if (!android.view.accessibility.Flags.a11yQsShortcut()
|
||||||
|
&& (shortcutType & QUICK_SETTINGS) == QUICK_SETTINGS) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (!android.provider.Flags.a11yStandaloneGestureEnabled()
|
||||||
|
&& (shortcutType & GESTURE) == GESTURE) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (!com.android.server.accessibility.Flags
|
||||||
|
.enableMagnificationMultipleFingerMultipleTapGesture()
|
||||||
|
&& (shortcutType & TWOFINGER_DOUBLETAP) == TWOFINGER_DOUBLETAP) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((shortcutTypes & shortcutType) == shortcutType) {
|
||||||
|
list.add(switch (shortcutType) {
|
||||||
|
case QUICK_SETTINGS -> context.getText(
|
||||||
|
R.string.accessibility_feature_shortcut_setting_summary_quick_settings);
|
||||||
|
case SOFTWARE -> getSoftwareShortcutSummary(context);
|
||||||
|
case GESTURE -> context.getText(
|
||||||
|
R.string.accessibility_shortcut_edit_summary_software_gesture);
|
||||||
|
case HARDWARE -> context.getText(
|
||||||
|
R.string.accessibility_shortcut_hardware_keyword);
|
||||||
|
case TWOFINGER_DOUBLETAP -> context.getString(
|
||||||
|
R.string.accessibility_shortcut_two_finger_double_tap_keyword, 2);
|
||||||
|
case TRIPLETAP -> context.getText(
|
||||||
|
R.string.accessibility_shortcut_triple_tap_keyword);
|
||||||
|
default -> "";
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
list.sort(CharSequence::compare);
|
||||||
|
return CaseMap.toTitle().wholeString().noLowercase().apply(Locale.getDefault(), /* iter= */
|
||||||
|
null, LocaleUtils.getConcatenatedString(list));
|
||||||
|
// LINT.ThenChange(/res/xml/accessibility_edit_shortcuts.xml:shortcut_type_ui_order)
|
||||||
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
static CharSequence getSoftwareShortcutSummary(Context context) {
|
||||||
|
if (android.provider.Flags.a11yStandaloneGestureEnabled()) {
|
||||||
|
return context.getText(R.string.accessibility_shortcut_edit_summary_software);
|
||||||
|
}
|
||||||
|
int resId;
|
||||||
|
if (AccessibilityUtil.isFloatingMenuEnabled(context)) {
|
||||||
|
resId = R.string.accessibility_shortcut_edit_summary_software;
|
||||||
|
} else if (AccessibilityUtil.isGestureNavigateEnabled(context)) {
|
||||||
|
resId = R.string.accessibility_shortcut_edit_summary_software_gesture;
|
||||||
|
} else {
|
||||||
|
resId = R.string.accessibility_shortcut_edit_summary_software;
|
||||||
|
}
|
||||||
|
return context.getText(resId);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -17,10 +17,9 @@
|
|||||||
package com.android.settings.accessibility;
|
package com.android.settings.accessibility;
|
||||||
|
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.DEFAULT;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.DEFAULT;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
||||||
import static com.android.settings.accessibility.AccessibilityDialogUtils.DialogEnums;
|
import static com.android.settings.accessibility.AccessibilityDialogUtils.DialogEnums;
|
||||||
|
import static com.android.settings.accessibility.AccessibilityUtil.getShortcutSummaryList;
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.app.Dialog;
|
import android.app.Dialog;
|
||||||
@@ -34,7 +33,6 @@ import android.content.pm.PackageManager;
|
|||||||
import android.content.pm.ResolveInfo;
|
import android.content.pm.ResolveInfo;
|
||||||
import android.content.pm.ServiceInfo;
|
import android.content.pm.ServiceInfo;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.icu.text.CaseMap;
|
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
@@ -59,14 +57,12 @@ import androidx.preference.PreferenceScreen;
|
|||||||
import androidx.recyclerview.widget.RecyclerView;
|
import androidx.recyclerview.widget.RecyclerView;
|
||||||
|
|
||||||
import com.android.internal.accessibility.common.ShortcutConstants;
|
import com.android.internal.accessibility.common.ShortcutConstants;
|
||||||
import com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType;
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SettingsActivity;
|
import com.android.settings.SettingsActivity;
|
||||||
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
||||||
import com.android.settings.accessibility.shortcuts.EditShortcutsPreferenceFragment;
|
import com.android.settings.accessibility.shortcuts.EditShortcutsPreferenceFragment;
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settings.flags.Flags;
|
import com.android.settings.flags.Flags;
|
||||||
import com.android.settings.utils.LocaleUtils;
|
|
||||||
import com.android.settings.widget.SettingsMainSwitchBar;
|
import com.android.settings.widget.SettingsMainSwitchBar;
|
||||||
import com.android.settings.widget.SettingsMainSwitchPreference;
|
import com.android.settings.widget.SettingsMainSwitchPreference;
|
||||||
import com.android.settingslib.widget.IllustrationPreference;
|
import com.android.settingslib.widget.IllustrationPreference;
|
||||||
@@ -76,7 +72,6 @@ import com.google.android.setupcompat.util.WizardManagerHelper;
|
|||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Base class for accessibility fragments with toggle, shortcut, some helper functions
|
* Base class for accessibility fragments with toggle, shortcut, some helper functions
|
||||||
@@ -627,10 +622,6 @@ public abstract class ToggleFeaturePreferenceFragment extends DashboardFragment
|
|||||||
mFooterPreferenceController.displayPreference(screen);
|
mFooterPreferenceController.displayPreference(screen);
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean hasShortcutType(int value, @UserShortcutType int type) {
|
|
||||||
return (value & type) == type;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected CharSequence getShortcutTypeSummary(Context context) {
|
protected CharSequence getShortcutTypeSummary(Context context) {
|
||||||
if (!mShortcutPreference.isSettingsEditable()) {
|
if (!mShortcutPreference.isSettingsEditable()) {
|
||||||
return context.getText(R.string.accessibility_shortcut_edit_dialog_title_hardware);
|
return context.getText(R.string.accessibility_shortcut_edit_dialog_title_hardware);
|
||||||
@@ -640,47 +631,9 @@ public abstract class ToggleFeaturePreferenceFragment extends DashboardFragment
|
|||||||
return context.getText(R.string.accessibility_shortcut_state_off);
|
return context.getText(R.string.accessibility_shortcut_state_off);
|
||||||
}
|
}
|
||||||
|
|
||||||
// LINT.IfChange(shortcut_type_ui_order)
|
|
||||||
final int shortcutTypes = PreferredShortcuts.retrieveUserShortcutType(
|
final int shortcutTypes = PreferredShortcuts.retrieveUserShortcutType(
|
||||||
context, mComponentName.flattenToString(), getDefaultShortcutTypes());
|
context, mComponentName.flattenToString(), getDefaultShortcutTypes());
|
||||||
|
return getShortcutSummaryList(context, shortcutTypes);
|
||||||
final List<CharSequence> list = new ArrayList<>();
|
|
||||||
if (android.view.accessibility.Flags.a11yQsShortcut()) {
|
|
||||||
if (hasShortcutType(shortcutTypes, QUICK_SETTINGS)) {
|
|
||||||
final CharSequence qsTitle = context.getText(
|
|
||||||
R.string.accessibility_feature_shortcut_setting_summary_quick_settings);
|
|
||||||
list.add(qsTitle);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (hasShortcutType(shortcutTypes, SOFTWARE)) {
|
|
||||||
list.add(getSoftwareShortcutTypeSummary(context));
|
|
||||||
}
|
|
||||||
if (hasShortcutType(shortcutTypes, HARDWARE)) {
|
|
||||||
final CharSequence hardwareTitle = context.getText(
|
|
||||||
R.string.accessibility_shortcut_hardware_keyword);
|
|
||||||
list.add(hardwareTitle);
|
|
||||||
}
|
|
||||||
// LINT.ThenChange(/res/xml/accessibility_edit_shortcuts.xml:shortcut_type_ui_order)
|
|
||||||
|
|
||||||
// Show software shortcut if first time to use.
|
|
||||||
if (list.isEmpty()) {
|
|
||||||
list.add(getSoftwareShortcutTypeSummary(context));
|
|
||||||
}
|
|
||||||
|
|
||||||
return CaseMap.toTitle().wholeString().noLowercase().apply(Locale.getDefault(), /* iter= */
|
|
||||||
null, LocaleUtils.getConcatenatedString(list));
|
|
||||||
}
|
|
||||||
|
|
||||||
private static CharSequence getSoftwareShortcutTypeSummary(Context context) {
|
|
||||||
int resId;
|
|
||||||
if (AccessibilityUtil.isFloatingMenuEnabled(context)) {
|
|
||||||
resId = R.string.accessibility_shortcut_edit_summary_software;
|
|
||||||
} else if (AccessibilityUtil.isGestureNavigateEnabled(context)) {
|
|
||||||
resId = R.string.accessibility_shortcut_edit_summary_software_gesture;
|
|
||||||
} else {
|
|
||||||
resId = R.string.accessibility_shortcut_edit_summary_software;
|
|
||||||
}
|
|
||||||
return context.getText(resId);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -19,6 +19,7 @@ package com.android.settings.accessibility;
|
|||||||
import static com.android.internal.accessibility.AccessibilityShortcutController.MAGNIFICATION_COMPONENT_NAME;
|
import static com.android.internal.accessibility.AccessibilityShortcutController.MAGNIFICATION_COMPONENT_NAME;
|
||||||
import static com.android.internal.accessibility.AccessibilityShortcutController.MAGNIFICATION_CONTROLLER_NAME;
|
import static com.android.internal.accessibility.AccessibilityShortcutController.MAGNIFICATION_CONTROLLER_NAME;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.DEFAULT;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.DEFAULT;
|
||||||
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.GESTURE;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
||||||
@@ -27,6 +28,7 @@ import static com.android.internal.accessibility.common.ShortcutConstants.UserSh
|
|||||||
import static com.android.settings.accessibility.AccessibilityDialogUtils.DialogEnums;
|
import static com.android.settings.accessibility.AccessibilityDialogUtils.DialogEnums;
|
||||||
import static com.android.settings.accessibility.AccessibilityUtil.State.OFF;
|
import static com.android.settings.accessibility.AccessibilityUtil.State.OFF;
|
||||||
import static com.android.settings.accessibility.AccessibilityUtil.State.ON;
|
import static com.android.settings.accessibility.AccessibilityUtil.State.ON;
|
||||||
|
import static com.android.settings.accessibility.AccessibilityUtil.getShortcutSummaryList;
|
||||||
|
|
||||||
import android.app.Dialog;
|
import android.app.Dialog;
|
||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
@@ -34,7 +36,6 @@ import android.content.ComponentName;
|
|||||||
import android.content.ContentResolver;
|
import android.content.ContentResolver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.icu.text.CaseMap;
|
|
||||||
import android.icu.text.MessageFormat;
|
import android.icu.text.MessageFormat;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
@@ -55,6 +56,7 @@ import androidx.preference.PreferenceCategory;
|
|||||||
import androidx.preference.SwitchPreferenceCompat;
|
import androidx.preference.SwitchPreferenceCompat;
|
||||||
import androidx.preference.TwoStatePreference;
|
import androidx.preference.TwoStatePreference;
|
||||||
|
|
||||||
|
import com.android.internal.accessibility.common.ShortcutConstants;
|
||||||
import com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType;
|
import com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType;
|
||||||
import com.android.internal.annotations.VisibleForTesting;
|
import com.android.internal.annotations.VisibleForTesting;
|
||||||
import com.android.server.accessibility.Flags;
|
import com.android.server.accessibility.Flags;
|
||||||
@@ -62,7 +64,6 @@ import com.android.settings.DialogCreatable;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
||||||
import com.android.settings.accessibility.shortcuts.EditShortcutsPreferenceFragment;
|
import com.android.settings.accessibility.shortcuts.EditShortcutsPreferenceFragment;
|
||||||
import com.android.settings.utils.LocaleUtils;
|
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
import com.android.settingslib.widget.IllustrationPreference;
|
import com.android.settingslib.widget.IllustrationPreference;
|
||||||
|
|
||||||
@@ -70,7 +71,6 @@ import com.google.android.setupcompat.util.WizardManagerHelper;
|
|||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.StringJoiner;
|
import java.util.StringJoiner;
|
||||||
|
|
||||||
@@ -348,22 +348,6 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
|||||||
mDialogDelegate = delegate;
|
mDialogDelegate = delegate;
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean hasShortcutType(int value, @UserShortcutType int type) {
|
|
||||||
return (value & type) == type;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static CharSequence getSoftwareShortcutTypeSummary(Context context) {
|
|
||||||
int resId;
|
|
||||||
if (AccessibilityUtil.isFloatingMenuEnabled(context)) {
|
|
||||||
resId = R.string.accessibility_shortcut_edit_summary_software;
|
|
||||||
} else if (AccessibilityUtil.isGestureNavigateEnabled(context)) {
|
|
||||||
resId = R.string.accessibility_shortcut_edit_summary_software_gesture;
|
|
||||||
} else {
|
|
||||||
resId = R.string.accessibility_shortcut_edit_summary_software;
|
|
||||||
}
|
|
||||||
return context.getText(resId);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void registerKeysToObserverCallback(
|
protected void registerKeysToObserverCallback(
|
||||||
AccessibilitySettingsContentObserver contentObserver) {
|
AccessibilitySettingsContentObserver contentObserver) {
|
||||||
@@ -423,47 +407,9 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
|||||||
return context.getText(R.string.switch_off_text);
|
return context.getText(R.string.switch_off_text);
|
||||||
}
|
}
|
||||||
|
|
||||||
final int shortcutTypes = PreferredShortcuts.retrieveUserShortcutType(context,
|
return getShortcutSummaryList(context,
|
||||||
MAGNIFICATION_CONTROLLER_NAME);
|
PreferredShortcuts.retrieveUserShortcutType(context,
|
||||||
|
MAGNIFICATION_CONTROLLER_NAME));
|
||||||
// LINT.IfChange(shortcut_type_ui_order)
|
|
||||||
final List<CharSequence> list = new ArrayList<>();
|
|
||||||
if (android.view.accessibility.Flags.a11yQsShortcut()) {
|
|
||||||
if (hasShortcutType(shortcutTypes, QUICK_SETTINGS)) {
|
|
||||||
final CharSequence qsTitle = context.getText(
|
|
||||||
R.string.accessibility_feature_shortcut_setting_summary_quick_settings);
|
|
||||||
list.add(qsTitle);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (hasShortcutType(shortcutTypes, SOFTWARE)) {
|
|
||||||
list.add(getSoftwareShortcutTypeSummary(context));
|
|
||||||
}
|
|
||||||
if (hasShortcutType(shortcutTypes, HARDWARE)) {
|
|
||||||
final CharSequence hardwareTitle = context.getText(
|
|
||||||
R.string.accessibility_shortcut_hardware_keyword);
|
|
||||||
list.add(hardwareTitle);
|
|
||||||
}
|
|
||||||
if (Flags.enableMagnificationMultipleFingerMultipleTapGesture()) {
|
|
||||||
if (hasShortcutType(shortcutTypes, TWOFINGER_DOUBLETAP)) {
|
|
||||||
final CharSequence twoFingerDoubleTapTitle = context.getString(
|
|
||||||
R.string.accessibility_shortcut_two_finger_double_tap_keyword, 2);
|
|
||||||
list.add(twoFingerDoubleTapTitle);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (hasShortcutType(shortcutTypes, TRIPLETAP)) {
|
|
||||||
final CharSequence tripleTapTitle = context.getText(
|
|
||||||
R.string.accessibility_shortcut_triple_tap_keyword);
|
|
||||||
list.add(tripleTapTitle);
|
|
||||||
}
|
|
||||||
// LINT.ThenChange(/res/xml/accessibility_edit_shortcuts.xml:shortcut_type_ui_order)
|
|
||||||
|
|
||||||
// Show software shortcut if first time to use.
|
|
||||||
if (list.isEmpty()) {
|
|
||||||
list.add(getSoftwareShortcutTypeSummary(context));
|
|
||||||
}
|
|
||||||
|
|
||||||
return CaseMap.toTitle().wholeString().noLowercase().apply(Locale.getDefault(), /* iter= */
|
|
||||||
null, LocaleUtils.getConcatenatedString(list));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -595,6 +541,9 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
|||||||
if (((shortcutTypes & TRIPLETAP) == TRIPLETAP)) {
|
if (((shortcutTypes & TRIPLETAP) == TRIPLETAP)) {
|
||||||
optInMagnificationValueToSettings(context, TRIPLETAP);
|
optInMagnificationValueToSettings(context, TRIPLETAP);
|
||||||
}
|
}
|
||||||
|
if (((shortcutTypes & GESTURE) == GESTURE)) {
|
||||||
|
optInMagnificationValueToSettings(context, GESTURE);
|
||||||
|
}
|
||||||
if (Flags.enableMagnificationMultipleFingerMultipleTapGesture()) {
|
if (Flags.enableMagnificationMultipleFingerMultipleTapGesture()) {
|
||||||
if (((shortcutTypes & TWOFINGER_DOUBLETAP)
|
if (((shortcutTypes & TWOFINGER_DOUBLETAP)
|
||||||
== TWOFINGER_DOUBLETAP)) {
|
== TWOFINGER_DOUBLETAP)) {
|
||||||
@@ -680,6 +629,9 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
|||||||
if (((shortcutTypes & TRIPLETAP) == TRIPLETAP)) {
|
if (((shortcutTypes & TRIPLETAP) == TRIPLETAP)) {
|
||||||
optOutMagnificationValueFromSettings(context, TRIPLETAP);
|
optOutMagnificationValueFromSettings(context, TRIPLETAP);
|
||||||
}
|
}
|
||||||
|
if (((shortcutTypes & GESTURE) == GESTURE)) {
|
||||||
|
optOutMagnificationValueFromSettings(context, GESTURE);
|
||||||
|
}
|
||||||
if (Flags.enableMagnificationMultipleFingerMultipleTapGesture()) {
|
if (Flags.enableMagnificationMultipleFingerMultipleTapGesture()) {
|
||||||
if (((shortcutTypes & TWOFINGER_DOUBLETAP)
|
if (((shortcutTypes & TWOFINGER_DOUBLETAP)
|
||||||
== TWOFINGER_DOUBLETAP)) {
|
== TWOFINGER_DOUBLETAP)) {
|
||||||
@@ -749,25 +701,21 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
|||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
static boolean hasMagnificationValuesInSettings(Context context, int shortcutTypes) {
|
static boolean hasMagnificationValuesInSettings(Context context, int shortcutTypes) {
|
||||||
boolean exist = false;
|
for (int shortcutType : ShortcutConstants.USER_SHORTCUT_TYPES) {
|
||||||
|
if ((shortcutTypes & shortcutType) == 0) {
|
||||||
if ((shortcutTypes & SOFTWARE) == SOFTWARE) {
|
continue;
|
||||||
exist = hasMagnificationValueInSettings(context, SOFTWARE);
|
}
|
||||||
}
|
if (((shortcutType & TWOFINGER_DOUBLETAP)
|
||||||
if (((shortcutTypes & HARDWARE) == HARDWARE)) {
|
== TWOFINGER_DOUBLETAP)
|
||||||
exist |= hasMagnificationValueInSettings(context, HARDWARE);
|
&& !Flags.enableMagnificationMultipleFingerMultipleTapGesture()) {
|
||||||
}
|
continue;
|
||||||
if (((shortcutTypes & TRIPLETAP) == TRIPLETAP)) {
|
}
|
||||||
exist |= hasMagnificationValueInSettings(context, TRIPLETAP);
|
if (hasMagnificationValueInSettings(context, shortcutType)) {
|
||||||
}
|
return true;
|
||||||
if (Flags.enableMagnificationMultipleFingerMultipleTapGesture()) {
|
|
||||||
if (((shortcutTypes & TWOFINGER_DOUBLETAP)
|
|
||||||
== TWOFINGER_DOUBLETAP)) {
|
|
||||||
exist |= hasMagnificationValueInSettings(context,
|
|
||||||
TWOFINGER_DOUBLETAP);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return exist;
|
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean hasMagnificationValueInSettings(Context context,
|
private static boolean hasMagnificationValueInSettings(Context context,
|
||||||
@@ -776,7 +724,6 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
|||||||
return Settings.Secure.getInt(context.getContentResolver(),
|
return Settings.Secure.getInt(context.getContentResolver(),
|
||||||
Settings.Secure.ACCESSIBILITY_DISPLAY_MAGNIFICATION_ENABLED, OFF) == ON;
|
Settings.Secure.ACCESSIBILITY_DISPLAY_MAGNIFICATION_ENABLED, OFF) == ON;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Flags.enableMagnificationMultipleFingerMultipleTapGesture()) {
|
if (Flags.enableMagnificationMultipleFingerMultipleTapGesture()) {
|
||||||
if (shortcutType == TWOFINGER_DOUBLETAP) {
|
if (shortcutType == TWOFINGER_DOUBLETAP) {
|
||||||
return Settings.Secure.getInt(context.getContentResolver(),
|
return Settings.Secure.getInt(context.getContentResolver(),
|
||||||
@@ -805,20 +752,18 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
|||||||
|
|
||||||
private static int getUserShortcutTypeFromSettings(Context context) {
|
private static int getUserShortcutTypeFromSettings(Context context) {
|
||||||
int shortcutTypes = DEFAULT;
|
int shortcutTypes = DEFAULT;
|
||||||
if (hasMagnificationValuesInSettings(context, SOFTWARE)) {
|
for (int shortcutType : ShortcutConstants.USER_SHORTCUT_TYPES) {
|
||||||
shortcutTypes |= SOFTWARE;
|
if ((shortcutType & (TWOFINGER_DOUBLETAP | QUICK_SETTINGS | GESTURE | TRIPLETAP))
|
||||||
}
|
== shortcutType
|
||||||
if (hasMagnificationValuesInSettings(context, HARDWARE)) {
|
&& !android.view.accessibility.Flags.a11yQsShortcut()) {
|
||||||
shortcutTypes |= HARDWARE;
|
// These shortcuts will throw if we try to look up their settings without the flag.
|
||||||
}
|
continue;
|
||||||
if (hasMagnificationValuesInSettings(context, TRIPLETAP)) {
|
}
|
||||||
shortcutTypes |= TRIPLETAP;
|
if (hasMagnificationValueInSettings(context, shortcutType)) {
|
||||||
}
|
shortcutTypes |= shortcutType;
|
||||||
if (Flags.enableMagnificationMultipleFingerMultipleTapGesture()) {
|
|
||||||
if (hasMagnificationValuesInSettings(context, TWOFINGER_DOUBLETAP)) {
|
|
||||||
shortcutTypes |= TWOFINGER_DOUBLETAP;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return shortcutTypes;
|
return shortcutTypes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -16,6 +16,8 @@
|
|||||||
|
|
||||||
package com.android.settings.accessibility;
|
package com.android.settings.accessibility;
|
||||||
|
|
||||||
|
import static android.provider.Settings.Secure.ACCESSIBILITY_BUTTON_MODE_GESTURE;
|
||||||
|
import static android.provider.Settings.Secure.NAVIGATION_MODE;
|
||||||
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_2BUTTON;
|
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_2BUTTON;
|
||||||
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_GESTURAL;
|
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_GESTURAL;
|
||||||
|
|
||||||
@@ -26,11 +28,17 @@ import static org.mockito.Mockito.when;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.res.Resources;
|
import android.content.res.Resources;
|
||||||
import android.icu.text.MessageFormat;
|
import android.icu.text.MessageFormat;
|
||||||
|
import android.platform.test.annotations.DisableFlags;
|
||||||
|
import android.platform.test.annotations.EnableFlags;
|
||||||
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
|
import android.provider.Flags;
|
||||||
|
import android.provider.Settings;
|
||||||
import android.text.Html;
|
import android.text.Html;
|
||||||
|
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.internal.accessibility.util.ShortcutUtils;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -47,6 +55,8 @@ import org.robolectric.RobolectricTestRunner;
|
|||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class AccessibilityButtonFooterPreferenceControllerTest {
|
public class AccessibilityButtonFooterPreferenceControllerTest {
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public final SetFlagsRule mCheckFlagsRule = new SetFlagsRule();
|
||||||
@Rule
|
@Rule
|
||||||
public final MockitoRule mockito = MockitoJUnit.rule();
|
public final MockitoRule mockito = MockitoJUnit.rule();
|
||||||
@Spy
|
@Spy
|
||||||
@@ -69,9 +79,12 @@ public class AccessibilityButtonFooterPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@DisableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
public void displayPreference_navigationGestureEnabled_setCorrectTitle() {
|
public void displayPreference_navigationGestureEnabled_setCorrectTitle() {
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
.thenReturn(NAV_BAR_MODE_GESTURAL);
|
NAVIGATION_MODE, NAV_BAR_MODE_GESTURAL, mContext.getUserId());
|
||||||
|
ShortcutUtils.setButtonMode(
|
||||||
|
mContext, ACCESSIBILITY_BUTTON_MODE_GESTURE, mContext.getUserId());
|
||||||
|
|
||||||
mController.displayPreference(mScreen);
|
mController.displayPreference(mScreen);
|
||||||
|
|
||||||
@@ -82,11 +95,26 @@ public class AccessibilityButtonFooterPreferenceControllerTest {
|
|||||||
Html.FROM_HTML_MODE_COMPACT).toString());
|
Html.FROM_HTML_MODE_COMPACT).toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@EnableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
|
public void displayPreference_navigationGestureEnabled_flag_setCorrectTitle() {
|
||||||
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
|
NAVIGATION_MODE, NAV_BAR_MODE_GESTURAL, mContext.getUserId());
|
||||||
|
|
||||||
|
assertThat(AccessibilityUtil.isGestureNavigateEnabled(mContext)).isTrue();
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
|
||||||
|
assertThat(mPreference.getTitle().toString()).isEqualTo(
|
||||||
|
Html.fromHtml(
|
||||||
|
MessageFormat.format(mContext.getString(
|
||||||
|
R.string.accessibility_button_description), 1, 2, 3),
|
||||||
|
Html.FROM_HTML_MODE_COMPACT).toString());
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void displayPreference_navigationGestureDisabled_setCorrectTitle() {
|
public void displayPreference_navigationGestureDisabled_setCorrectTitle() {
|
||||||
when(mResources.getInteger(
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
com.android.internal.R.integer.config_navBarInteractionMode)).thenReturn(
|
NAVIGATION_MODE, NAV_BAR_MODE_2BUTTON, mContext.getUserId());
|
||||||
NAV_BAR_MODE_2BUTTON);
|
|
||||||
|
|
||||||
mController.displayPreference(mScreen);
|
mController.displayPreference(mScreen);
|
||||||
|
|
||||||
|
@@ -32,6 +32,7 @@ import android.platform.test.annotations.DisableFlags;
|
|||||||
import android.platform.test.annotations.EnableFlags;
|
import android.platform.test.annotations.EnableFlags;
|
||||||
import android.platform.test.flag.junit.SetFlagsRule;
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
import android.provider.Flags;
|
import android.provider.Flags;
|
||||||
|
import android.provider.Settings;
|
||||||
|
|
||||||
import androidx.fragment.app.FragmentActivity;
|
import androidx.fragment.app.FragmentActivity;
|
||||||
import androidx.preference.PreferenceManager;
|
import androidx.preference.PreferenceManager;
|
||||||
@@ -92,8 +93,9 @@ public class AccessibilityButtonFragmentTest {
|
|||||||
@Test
|
@Test
|
||||||
@DisableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
@DisableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
public void onCreate_navigationGestureEnabled_setCorrectTitle() {
|
public void onCreate_navigationGestureEnabled_setCorrectTitle() {
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.putIntForUser(
|
||||||
.thenReturn(NAV_BAR_MODE_GESTURAL);
|
mContext.getContentResolver(), Settings.Secure.NAVIGATION_MODE,
|
||||||
|
NAV_BAR_MODE_GESTURAL, mContext.getUserId());
|
||||||
|
|
||||||
mFragment.onAttach(mContext);
|
mFragment.onAttach(mContext);
|
||||||
mFragment.onCreate(Bundle.EMPTY);
|
mFragment.onCreate(Bundle.EMPTY);
|
||||||
@@ -104,9 +106,10 @@ public class AccessibilityButtonFragmentTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
@EnableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
@EnableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
public void onCreate_navigationGestureEnabled_gestureFlag_setCorrectTitle() {
|
public void onCreate_navigationGestureEnabled_flag_setCorrectTitle() {
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.putIntForUser(
|
||||||
.thenReturn(NAV_BAR_MODE_GESTURAL);
|
mContext.getContentResolver(), Settings.Secure.NAVIGATION_MODE,
|
||||||
|
NAV_BAR_MODE_GESTURAL, mContext.getUserId());
|
||||||
|
|
||||||
mFragment.onAttach(mContext);
|
mFragment.onAttach(mContext);
|
||||||
mFragment.onCreate(Bundle.EMPTY);
|
mFragment.onCreate(Bundle.EMPTY);
|
||||||
@@ -117,8 +120,9 @@ public class AccessibilityButtonFragmentTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onCreate_navigationBarEnabled_setCorrectTitle() {
|
public void onCreate_navigationBarEnabled_setCorrectTitle() {
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.putIntForUser(
|
||||||
.thenReturn(NAV_BAR_MODE_2BUTTON);
|
mContext.getContentResolver(), Settings.Secure.NAVIGATION_MODE,
|
||||||
|
NAV_BAR_MODE_2BUTTON, mContext.getUserId());
|
||||||
|
|
||||||
mFragment.onAttach(mContext);
|
mFragment.onAttach(mContext);
|
||||||
mFragment.onCreate(Bundle.EMPTY);
|
mFragment.onCreate(Bundle.EMPTY);
|
||||||
|
@@ -75,26 +75,25 @@ public class AccessibilityButtonGesturePreferenceControllerTest {
|
|||||||
@Test
|
@Test
|
||||||
@DisableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
@DisableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
public void getAvailabilityStatus_navigationGestureEnabled_returnAvailable() {
|
public void getAvailabilityStatus_navigationGestureEnabled_returnAvailable() {
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
.thenReturn(NAV_BAR_MODE_GESTURAL);
|
Settings.Secure.NAVIGATION_MODE, NAV_BAR_MODE_GESTURAL, mContext.getUserId());
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@EnableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
@EnableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
public void
|
public void getAvailabilityStatus_navigationGestureEnabled_returnConditionallyUnavailable() {
|
||||||
getAvailabilityStatus_navigationGestureEnabled_gestureFlag_conditionallyUnavailable() {
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.NAVIGATION_MODE, NAV_BAR_MODE_GESTURAL, mContext.getUserId());
|
||||||
.thenReturn(NAV_BAR_MODE_GESTURAL);
|
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_navigationGestureDisabled_returnConditionallyUnavailable() {
|
public void getAvailabilityStatus_navigationGestureDisabled_returnConditionallyUnavailable() {
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
.thenReturn(NAV_BAR_MODE_2BUTTON);
|
Settings.Secure.NAVIGATION_MODE, NAV_BAR_MODE_2BUTTON, mContext.getUserId());
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
||||||
}
|
}
|
||||||
|
@@ -69,16 +69,16 @@ public class AccessibilityButtonLocationPreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_navigationGestureEnabled_returnConditionallyUnavailable() {
|
public void getAvailabilityStatus_navigationGestureEnabled_returnConditionallyUnavailable() {
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
.thenReturn(NAV_BAR_MODE_GESTURAL);
|
Settings.Secure.NAVIGATION_MODE, NAV_BAR_MODE_GESTURAL, mContext.getUserId());
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(CONDITIONALLY_UNAVAILABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_navigationGestureDisabled_returnAvailable() {
|
public void getAvailabilityStatus_navigationGestureDisabled_returnAvailable() {
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
.thenReturn(NAV_BAR_MODE_2BUTTON);
|
Settings.Secure.NAVIGATION_MODE, NAV_BAR_MODE_2BUTTON, mContext.getUserId());
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
||||||
}
|
}
|
||||||
|
@@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
package com.android.settings.accessibility;
|
package com.android.settings.accessibility;
|
||||||
|
|
||||||
|
import static android.provider.Settings.Secure.NAVIGATION_MODE;
|
||||||
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_2BUTTON;
|
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_2BUTTON;
|
||||||
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_GESTURAL;
|
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_GESTURAL;
|
||||||
|
|
||||||
@@ -25,6 +26,11 @@ import static org.mockito.Mockito.when;
|
|||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.res.Resources;
|
import android.content.res.Resources;
|
||||||
|
import android.platform.test.annotations.DisableFlags;
|
||||||
|
import android.platform.test.annotations.EnableFlags;
|
||||||
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
|
import android.provider.Flags;
|
||||||
|
import android.provider.Settings;
|
||||||
|
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
@@ -50,6 +56,8 @@ import java.util.List;
|
|||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class AccessibilityButtonPreferenceControllerTest {
|
public class AccessibilityButtonPreferenceControllerTest {
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public final SetFlagsRule mSetFlagsRule = new SetFlagsRule();
|
||||||
@Rule
|
@Rule
|
||||||
public final MockitoRule mockito = MockitoJUnit.rule();
|
public final MockitoRule mockito = MockitoJUnit.rule();
|
||||||
@Spy
|
@Spy
|
||||||
@@ -72,9 +80,10 @@ public class AccessibilityButtonPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@DisableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
public void displayPreference_navigationGestureEnabled_setCorrectTitle() {
|
public void displayPreference_navigationGestureEnabled_setCorrectTitle() {
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
.thenReturn(NAV_BAR_MODE_GESTURAL);
|
NAVIGATION_MODE, NAV_BAR_MODE_GESTURAL, mContext.getUserId());
|
||||||
|
|
||||||
mController.displayPreference(mScreen);
|
mController.displayPreference(mScreen);
|
||||||
|
|
||||||
@@ -83,9 +92,10 @@ public class AccessibilityButtonPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void displayPreference_navigationGestureDisabled_setCorrectTitle() {
|
@EnableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
public void displayPreference_navigationGestureEnabled_flag_setCorrectTitle() {
|
||||||
.thenReturn(NAV_BAR_MODE_2BUTTON);
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
|
NAVIGATION_MODE, NAV_BAR_MODE_GESTURAL, mContext.getUserId());
|
||||||
|
|
||||||
mController.displayPreference(mScreen);
|
mController.displayPreference(mScreen);
|
||||||
|
|
||||||
@@ -94,9 +104,21 @@ public class AccessibilityButtonPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
public void displayPreference_navigationGestureDisabled_setCorrectTitle() {
|
||||||
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
|
NAVIGATION_MODE, NAV_BAR_MODE_2BUTTON, mContext.getUserId());
|
||||||
|
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
|
||||||
|
assertThat(mPreference.getTitle()).isEqualTo(
|
||||||
|
mContext.getText(R.string.accessibility_button_title));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
public void updateDynamicRawDataToIndex_navigationGestureEnabled_setCorrectIndex() {
|
public void updateDynamicRawDataToIndex_navigationGestureEnabled_setCorrectIndex() {
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
.thenReturn(NAV_BAR_MODE_GESTURAL);
|
NAVIGATION_MODE, NAV_BAR_MODE_GESTURAL, mContext.getUserId());
|
||||||
List<SearchIndexableRaw> rawDataList = new ArrayList<>();
|
List<SearchIndexableRaw> rawDataList = new ArrayList<>();
|
||||||
|
|
||||||
mController.updateDynamicRawDataToIndex(rawDataList);
|
mController.updateDynamicRawDataToIndex(rawDataList);
|
||||||
@@ -109,10 +131,27 @@ public class AccessibilityButtonPreferenceControllerTest {
|
|||||||
mResources.getString(R.string.accessibility_shortcuts_settings_title));
|
mResources.getString(R.string.accessibility_shortcuts_settings_title));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@EnableFlags(Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
|
public void updateDynamicRawDataToIndex_navigationGestureEnabled_flag_setCorrectIndex() {
|
||||||
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
|
NAVIGATION_MODE, NAV_BAR_MODE_GESTURAL, mContext.getUserId());
|
||||||
|
List<SearchIndexableRaw> rawDataList = new ArrayList<>();
|
||||||
|
|
||||||
|
mController.updateDynamicRawDataToIndex(rawDataList);
|
||||||
|
|
||||||
|
assertThat(rawDataList).hasSize(1);
|
||||||
|
SearchIndexableRaw raw = rawDataList.get(0);
|
||||||
|
assertThat(raw.title).isEqualTo(
|
||||||
|
mResources.getString(R.string.accessibility_button_title));
|
||||||
|
assertThat(raw.screenTitle).isEqualTo(
|
||||||
|
mResources.getString(R.string.accessibility_shortcuts_settings_title));
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateDynamicRawDataToIndex_navigationGestureDisabled_setCorrectIndex() {
|
public void updateDynamicRawDataToIndex_navigationGestureDisabled_setCorrectIndex() {
|
||||||
when(mResources.getInteger(com.android.internal.R.integer.config_navBarInteractionMode))
|
Settings.Secure.putIntForUser(mContext.getContentResolver(),
|
||||||
.thenReturn(NAV_BAR_MODE_2BUTTON);
|
NAVIGATION_MODE, NAV_BAR_MODE_2BUTTON, mContext.getUserId());
|
||||||
List<SearchIndexableRaw> rawDataList = new ArrayList<>();
|
List<SearchIndexableRaw> rawDataList = new ArrayList<>();
|
||||||
|
|
||||||
mController.updateDynamicRawDataToIndex(rawDataList);
|
mController.updateDynamicRawDataToIndex(rawDataList);
|
||||||
|
@@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
package com.android.settings.accessibility;
|
package com.android.settings.accessibility;
|
||||||
|
|
||||||
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.GESTURE;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
||||||
@@ -36,6 +37,7 @@ import android.app.settings.SettingsEnums;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
import android.platform.test.annotations.DisableFlags;
|
||||||
import android.platform.test.annotations.EnableFlags;
|
import android.platform.test.annotations.EnableFlags;
|
||||||
import android.platform.test.flag.junit.SetFlagsRule;
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
import android.text.SpannableStringBuilder;
|
import android.text.SpannableStringBuilder;
|
||||||
@@ -479,9 +481,37 @@ public final class AccessibilityShortcutsTutorialTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@DisableFlags(android.provider.Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
public void createAccessibilityTutorialDialog_gestureShortcut_talkbackOn_verifyText() {
|
public void createAccessibilityTutorialDialog_gestureShortcut_talkbackOn_verifyText() {
|
||||||
mShortcutTypes |= SOFTWARE;
|
mShortcutTypes |= SOFTWARE;
|
||||||
setTouchExplorationEnabled(true);
|
setTouchExplorationEnabled(true);
|
||||||
|
AccessibilityTestUtils.setSoftwareShortcutMode(
|
||||||
|
mContext, /* gestureNavEnabled= */ true, /* floatingButtonEnabled= */ false);
|
||||||
|
|
||||||
|
final String expectedTitle = mContext.getString(
|
||||||
|
R.string.accessibility_tutorial_dialog_title_gesture);
|
||||||
|
final String expectedInstruction = StringUtil.getIcuPluralsString(
|
||||||
|
mContext,
|
||||||
|
/* count= */ 3,
|
||||||
|
R.string.accessibility_tutorial_dialog_gesture_shortcut_instruction);
|
||||||
|
|
||||||
|
final AlertDialog alertDialog =
|
||||||
|
createAccessibilityTutorialDialog(
|
||||||
|
mContext, mShortcutTypes, FAKE_FEATURE_NAME);
|
||||||
|
alertDialog.show();
|
||||||
|
ShadowLooper.idleMainLooper();
|
||||||
|
|
||||||
|
verifyTutorialTitleAndInstruction(
|
||||||
|
alertDialog,
|
||||||
|
expectedTitle,
|
||||||
|
expectedInstruction);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@EnableFlags(android.provider.Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
|
public void createAccessibilityTutorialDialog_gestureShortcut_talkbackOn_flag_verifyText() {
|
||||||
|
mShortcutTypes |= GESTURE;
|
||||||
|
setTouchExplorationEnabled(true);
|
||||||
AccessibilityTestUtils.setSoftwareShortcutMode(
|
AccessibilityTestUtils.setSoftwareShortcutMode(
|
||||||
mContext, /* gestureNavEnabled= */ true, /* floatingButtonEnabled= */ false);
|
mContext, /* gestureNavEnabled= */ true, /* floatingButtonEnabled= */ false);
|
||||||
final String expectedTitle = mContext.getString(
|
final String expectedTitle = mContext.getString(
|
||||||
@@ -504,6 +534,7 @@ public final class AccessibilityShortcutsTutorialTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@DisableFlags(android.provider.Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
public void createAccessibilityTutorialDialog_gestureShortcut_talkbackOff_verifyText() {
|
public void createAccessibilityTutorialDialog_gestureShortcut_talkbackOff_verifyText() {
|
||||||
mShortcutTypes |= SOFTWARE;
|
mShortcutTypes |= SOFTWARE;
|
||||||
setTouchExplorationEnabled(false);
|
setTouchExplorationEnabled(false);
|
||||||
@@ -528,6 +559,32 @@ public final class AccessibilityShortcutsTutorialTest {
|
|||||||
expectedInstruction);
|
expectedInstruction);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@EnableFlags(android.provider.Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
|
public void createAccessibilityTutorialDialog_gestureShortcut_talkbackOff_flag_verifyText() {
|
||||||
|
mShortcutTypes |= GESTURE;
|
||||||
|
setTouchExplorationEnabled(false);
|
||||||
|
AccessibilityTestUtils.setSoftwareShortcutMode(
|
||||||
|
mContext, /* gestureNavEnabled= */ true, /* floatingButtonEnabled= */ false);
|
||||||
|
final String expectedTitle = mContext.getString(
|
||||||
|
R.string.accessibility_tutorial_dialog_title_gesture);
|
||||||
|
final String expectedInstruction = StringUtil.getIcuPluralsString(
|
||||||
|
mContext,
|
||||||
|
/* count= */ 2,
|
||||||
|
R.string.accessibility_tutorial_dialog_gesture_shortcut_instruction);
|
||||||
|
|
||||||
|
final AlertDialog alertDialog =
|
||||||
|
createAccessibilityTutorialDialog(
|
||||||
|
mContext, mShortcutTypes, FAKE_FEATURE_NAME);
|
||||||
|
alertDialog.show();
|
||||||
|
ShadowLooper.idleMainLooper();
|
||||||
|
|
||||||
|
verifyTutorialTitleAndInstruction(
|
||||||
|
alertDialog,
|
||||||
|
expectedTitle,
|
||||||
|
expectedInstruction);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void performClickOnPositiveButton_turnOnSoftwareShortcut_dismiss() {
|
public void performClickOnPositiveButton_turnOnSoftwareShortcut_dismiss() {
|
||||||
mShortcutTypes |= SOFTWARE;
|
mShortcutTypes |= SOFTWARE;
|
||||||
|
@@ -16,6 +16,11 @@
|
|||||||
|
|
||||||
package com.android.settings.accessibility;
|
package com.android.settings.accessibility;
|
||||||
|
|
||||||
|
import static android.provider.Settings.Secure.ACCESSIBILITY_BUTTON_MODE_FLOATING_MENU;
|
||||||
|
import static android.provider.Settings.Secure.ACCESSIBILITY_BUTTON_MODE_GESTURE;
|
||||||
|
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_3BUTTON;
|
||||||
|
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_GESTURAL;
|
||||||
|
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.HARDWARE;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.QUICK_SETTINGS;
|
||||||
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType.SOFTWARE;
|
||||||
@@ -398,6 +403,49 @@ public final class AccessibilityUtilTest {
|
|||||||
.isEqualTo(Settings.Secure.ACCESSIBILITY_QS_TARGETS);
|
.isEqualTo(Settings.Secure.ACCESSIBILITY_QS_TARGETS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@EnableFlags(android.provider.Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
|
public void getSoftwareShortcutSummary_returnsSoftwareSummary() {
|
||||||
|
assertThat(AccessibilityUtil.getSoftwareShortcutSummary(mContext)).isEqualTo(
|
||||||
|
mContext.getText(R.string.accessibility_shortcut_edit_summary_software));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisableFlags(android.provider.Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
|
public void getSoftwareShortcutSummary_gestureMode_floatingButton_returnsSoftwareSummary() {
|
||||||
|
Settings.Secure.putInt(mContext.getContentResolver(),
|
||||||
|
Settings.Secure.NAVIGATION_MODE, NAV_BAR_MODE_GESTURAL);
|
||||||
|
Settings.Secure.putInt(mContext.getContentResolver(),
|
||||||
|
Settings.Secure.ACCESSIBILITY_BUTTON_MODE,
|
||||||
|
ACCESSIBILITY_BUTTON_MODE_FLOATING_MENU);
|
||||||
|
|
||||||
|
assertThat(AccessibilityUtil.getSoftwareShortcutSummary(mContext)).isEqualTo(
|
||||||
|
mContext.getText(R.string.accessibility_shortcut_edit_summary_software));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisableFlags(android.provider.Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
|
public void getSoftwareShortcutSummary_gestureMode_gesture_returnsGestureSummary() {
|
||||||
|
Settings.Secure.putInt(mContext.getContentResolver(),
|
||||||
|
Settings.Secure.NAVIGATION_MODE, NAV_BAR_MODE_GESTURAL);
|
||||||
|
Settings.Secure.putInt(mContext.getContentResolver(),
|
||||||
|
Settings.Secure.ACCESSIBILITY_BUTTON_MODE,
|
||||||
|
ACCESSIBILITY_BUTTON_MODE_GESTURE);
|
||||||
|
|
||||||
|
assertThat(AccessibilityUtil.getSoftwareShortcutSummary(mContext)).isEqualTo(
|
||||||
|
mContext.getText(R.string.accessibility_shortcut_edit_summary_software_gesture));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisableFlags(android.provider.Flags.FLAG_A11Y_STANDALONE_GESTURE_ENABLED)
|
||||||
|
public void getSoftwareShortcutSummary_navBarMode_returnsSoftwareSummary() {
|
||||||
|
Settings.Secure.putInt(mContext.getContentResolver(),
|
||||||
|
Settings.Secure.NAVIGATION_MODE, NAV_BAR_MODE_3BUTTON);
|
||||||
|
|
||||||
|
assertThat(AccessibilityUtil.getSoftwareShortcutSummary(mContext)).isEqualTo(
|
||||||
|
mContext.getText(R.string.accessibility_shortcut_edit_summary_software));
|
||||||
|
}
|
||||||
|
|
||||||
private AccessibilityServiceInfo getMockAccessibilityServiceInfo() {
|
private AccessibilityServiceInfo getMockAccessibilityServiceInfo() {
|
||||||
final ApplicationInfo applicationInfo = new ApplicationInfo();
|
final ApplicationInfo applicationInfo = new ApplicationInfo();
|
||||||
final ServiceInfo serviceInfo = new ServiceInfo();
|
final ServiceInfo serviceInfo = new ServiceInfo();
|
||||||
|
@@ -17,11 +17,11 @@
|
|||||||
package com.android.settings.testutils;
|
package com.android.settings.testutils;
|
||||||
|
|
||||||
import static android.provider.Settings.Secure.ACCESSIBILITY_BUTTON_MODE_FLOATING_MENU;
|
import static android.provider.Settings.Secure.ACCESSIBILITY_BUTTON_MODE_FLOATING_MENU;
|
||||||
|
import static android.provider.Settings.Secure.ACCESSIBILITY_BUTTON_MODE_GESTURE;
|
||||||
|
import static android.provider.Settings.Secure.ACCESSIBILITY_BUTTON_MODE_NAVIGATION_BAR;
|
||||||
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_3BUTTON;
|
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_3BUTTON;
|
||||||
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_GESTURAL;
|
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_GESTURAL;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
|
||||||
|
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
@@ -35,8 +35,6 @@ import android.os.Build;
|
|||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.view.accessibility.AccessibilityManager;
|
import android.view.accessibility.AccessibilityManager;
|
||||||
|
|
||||||
import com.android.settings.testutils.shadow.SettingsShadowResources;
|
|
||||||
|
|
||||||
import org.xmlpull.v1.XmlPullParserException;
|
import org.xmlpull.v1.XmlPullParserException;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
@@ -48,15 +46,18 @@ public class AccessibilityTestUtils {
|
|||||||
|
|
||||||
public static void setSoftwareShortcutMode(
|
public static void setSoftwareShortcutMode(
|
||||||
Context context, boolean gestureNavEnabled, boolean floatingButtonEnabled) {
|
Context context, boolean gestureNavEnabled, boolean floatingButtonEnabled) {
|
||||||
int buttonMode = floatingButtonEnabled ? ACCESSIBILITY_BUTTON_MODE_FLOATING_MENU : -1;
|
int buttonMode = ACCESSIBILITY_BUTTON_MODE_NAVIGATION_BAR;
|
||||||
|
if (floatingButtonEnabled) {
|
||||||
|
buttonMode = ACCESSIBILITY_BUTTON_MODE_FLOATING_MENU;
|
||||||
|
} else if (gestureNavEnabled) {
|
||||||
|
buttonMode = ACCESSIBILITY_BUTTON_MODE_GESTURE;
|
||||||
|
}
|
||||||
int navMode = gestureNavEnabled ? NAV_BAR_MODE_GESTURAL : NAV_BAR_MODE_3BUTTON;
|
int navMode = gestureNavEnabled ? NAV_BAR_MODE_GESTURAL : NAV_BAR_MODE_3BUTTON;
|
||||||
|
|
||||||
Settings.Secure.putInt(context.getContentResolver(),
|
Settings.Secure.putIntForUser(context.getContentResolver(),
|
||||||
Settings.Secure.ACCESSIBILITY_BUTTON_MODE, buttonMode);
|
Settings.Secure.ACCESSIBILITY_BUTTON_MODE, buttonMode, context.getUserId());
|
||||||
SettingsShadowResources.overrideResource(
|
Settings.Secure.putIntForUser(context.getContentResolver(),
|
||||||
com.android.internal.R.integer.config_navBarInteractionMode, navMode);
|
Settings.Secure.NAVIGATION_MODE, navMode, context.getUserId());
|
||||||
assertThat(context.getResources().getInteger(
|
|
||||||
com.android.internal.R.integer.config_navBarInteractionMode)).isEqualTo(navMode);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Reference in New Issue
Block a user