summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Peter_Liang <peterliang@google.com> 2020-03-05 20:18:16 +0800
committer Peter_Liang <peterliang@google.com> 2020-03-08 21:25:25 +0800
commit1e20bc41476a19f5ef4cf7e816ef50078aba0972 (patch)
tree1cf0f8873a60ec707b0d417152ef37dbe6149490
parent6a2213ae2e416dc81c2bef4f77a0073bae7f5f77 (diff)
Update the edit shortcut menu (2/n).
Add checkbox into list item and change the beavior. Bug: 148989057 Test: manual test Change-Id: I7782898582c2f9759d4ef466d2864f124d8c83be
-rw-r--r--core/java/com/android/internal/accessibility/common/ShortcutConstants.java15
-rw-r--r--core/java/com/android/internal/accessibility/util/ShortcutUtils.java27
-rw-r--r--core/java/com/android/internal/app/AccessibilityButtonChooserActivity.java244
-rw-r--r--core/res/res/layout/accessibility_button_chooser_item.xml40
-rw-r--r--core/res/res/values/strings.xml4
-rw-r--r--core/res/res/values/symbols.xml5
6 files changed, 215 insertions, 120 deletions
diff --git a/core/java/com/android/internal/accessibility/common/ShortcutConstants.java b/core/java/com/android/internal/accessibility/common/ShortcutConstants.java
index 1daa5052a565..72c30f974060 100644
--- a/core/java/com/android/internal/accessibility/common/ShortcutConstants.java
+++ b/core/java/com/android/internal/accessibility/common/ShortcutConstants.java
@@ -80,6 +80,21 @@ public final class ShortcutConstants {
}
/**
+ * Annotation for different shortcut target.
+ */
+ @Retention(RetentionPolicy.SOURCE)
+ @IntDef({
+ TargetType.ACCESSIBILITY_SERVICE,
+ TargetType.ACCESSIBILITY_ACTIVITY,
+ TargetType.WHITE_LISTING,
+ })
+ public @interface TargetType {
+ int ACCESSIBILITY_SERVICE = 0;
+ int ACCESSIBILITY_ACTIVITY = 1;
+ int WHITE_LISTING = 2;
+ }
+
+ /**
* Annotation for different shortcut menu mode.
*
* {@code LAUNCH} for clicking list item to trigger the service callback.
diff --git a/core/java/com/android/internal/accessibility/util/ShortcutUtils.java b/core/java/com/android/internal/accessibility/util/ShortcutUtils.java
index 7df712fbcf7b..717e78078b1c 100644
--- a/core/java/com/android/internal/accessibility/util/ShortcutUtils.java
+++ b/core/java/com/android/internal/accessibility/util/ShortcutUtils.java
@@ -39,6 +39,33 @@ public final class ShortcutUtils {
new TextUtils.SimpleStringSplitter(SERVICES_SEPARATOR);
/**
+ * Opts in component name into colon-separated {@link UserShortcutType}
+ * key's string in Settings.
+ *
+ * @param context The current context.
+ * @param shortcutType The preferred shortcut type user selected.
+ * @param componentId The component id that need to be opted out from Settings.
+ */
+ public static void optInValueToSettings(Context context, @UserShortcutType int shortcutType,
+ String componentId) {
+ final StringJoiner joiner = new StringJoiner(String.valueOf(SERVICES_SEPARATOR));
+ final String targetKey = convertToKey(shortcutType);
+ final String targetString = Settings.Secure.getString(context.getContentResolver(),
+ targetKey);
+
+ if (hasValueInSettings(context, shortcutType, componentId)) {
+ return;
+ }
+
+ if (!TextUtils.isEmpty(targetString)) {
+ joiner.add(targetString);
+ }
+ joiner.add(componentId);
+
+ Settings.Secure.putString(context.getContentResolver(), targetKey, joiner.toString());
+ }
+
+ /**
* Opts out component name into colon-separated {@code shortcutType} key's string in Settings.
*
* @param context The current context.
diff --git a/core/java/com/android/internal/app/AccessibilityButtonChooserActivity.java b/core/java/com/android/internal/app/AccessibilityButtonChooserActivity.java
index 852deb208ea6..8672175005b4 100644
--- a/core/java/com/android/internal/app/AccessibilityButtonChooserActivity.java
+++ b/core/java/com/android/internal/app/AccessibilityButtonChooserActivity.java
@@ -26,6 +26,7 @@ import static com.android.internal.accessibility.common.ShortcutConstants.Access
import static com.android.internal.accessibility.common.ShortcutConstants.DISABLED_ALPHA;
import static com.android.internal.accessibility.common.ShortcutConstants.ENABLED_ALPHA;
import static com.android.internal.accessibility.common.ShortcutConstants.ShortcutMenuMode;
+import static com.android.internal.accessibility.common.ShortcutConstants.TargetType;
import static com.android.internal.accessibility.common.ShortcutConstants.UserShortcutType;
import static com.android.internal.accessibility.common.ShortcutConstants.WhiteListingFeatureElementIndex.COMPONENT_ID;
import static com.android.internal.accessibility.common.ShortcutConstants.WhiteListingFeatureElementIndex.FRAGMENT_TYPE;
@@ -36,6 +37,7 @@ import static com.android.internal.accessibility.util.AccessibilityUtils.getAcce
import static com.android.internal.accessibility.util.AccessibilityUtils.setAccessibilityServiceState;
import static com.android.internal.accessibility.util.ShortcutUtils.convertToUserType;
import static com.android.internal.accessibility.util.ShortcutUtils.hasValuesInSettings;
+import static com.android.internal.accessibility.util.ShortcutUtils.optInValueToSettings;
import static com.android.internal.accessibility.util.ShortcutUtils.optOutValueFromSettings;
import static com.android.internal.util.Preconditions.checkArgument;
@@ -62,7 +64,7 @@ import android.view.Window;
import android.view.accessibility.AccessibilityManager;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
-import android.widget.FrameLayout;
+import android.widget.CheckBox;
import android.widget.ImageView;
import android.widget.Switch;
import android.widget.TextView;
@@ -78,12 +80,13 @@ import java.util.List;
*/
public class AccessibilityButtonChooserActivity extends Activity {
@ShortcutType
- private int mShortcutType;
+ private static int sShortcutType;
@UserShortcutType
private int mShortcutUserType;
private final List<AccessibilityButtonTarget> mTargets = new ArrayList<>();
private AlertDialog mAlertDialog;
private TargetAdapter mTargetAdapter;
+ private AccessibilityButtonTarget mCurrentCheckedTarget;
private static final String[][] WHITE_LISTING_FEATURES = {
{
@@ -118,19 +121,19 @@ public class AccessibilityButtonChooserActivity extends Activity {
requestWindowFeature(Window.FEATURE_NO_TITLE);
}
- mShortcutType = getIntent().getIntExtra(AccessibilityManager.EXTRA_SHORTCUT_TYPE,
+ sShortcutType = getIntent().getIntExtra(AccessibilityManager.EXTRA_SHORTCUT_TYPE,
/* unexpectedShortcutType */ -1);
- final boolean existInShortcutType = (mShortcutType == ACCESSIBILITY_BUTTON)
- || (mShortcutType == ACCESSIBILITY_SHORTCUT_KEY);
- checkArgument(existInShortcutType, "Unexpected shortcut type: " + mShortcutType);
+ final boolean existInShortcutType = (sShortcutType == ACCESSIBILITY_BUTTON)
+ || (sShortcutType == ACCESSIBILITY_SHORTCUT_KEY);
+ checkArgument(existInShortcutType, "Unexpected shortcut type: " + sShortcutType);
- mShortcutUserType = convertToUserType(mShortcutType);
+ mShortcutUserType = convertToUserType(sShortcutType);
- mTargets.addAll(getServiceTargets(this, mShortcutType));
+ mTargets.addAll(getServiceTargets(this, sShortcutType));
final String selectDialogTitle =
getString(R.string.accessibility_select_shortcut_menu_title);
- mTargetAdapter = new TargetAdapter(mTargets, mShortcutType);
+ mTargetAdapter = new TargetAdapter(mTargets, sShortcutType);
mAlertDialog = new AlertDialog.Builder(this)
.setTitle(selectDialogTitle)
.setAdapter(mTargetAdapter, /* listener= */ null)
@@ -151,15 +154,21 @@ public class AccessibilityButtonChooserActivity extends Activity {
private static List<AccessibilityButtonTarget> getServiceTargets(@NonNull Context context,
@ShortcutType int shortcutType) {
+ final List<AccessibilityButtonTarget> targets = getInstalledServiceTargets(context);
+ final AccessibilityManager ams = context.getSystemService(AccessibilityManager.class);
+ final List<String> requiredTargets = ams.getAccessibilityShortcutTargets(shortcutType);
+ targets.removeIf(target -> !requiredTargets.contains(target.getId()));
+
+ return targets;
+ }
+
+ private static List<AccessibilityButtonTarget> getInstalledServiceTargets(
+ @NonNull Context context) {
final List<AccessibilityButtonTarget> targets = new ArrayList<>();
targets.addAll(getAccessibilityServiceTargets(context));
targets.addAll(getAccessibilityActivityTargets(context));
targets.addAll(getWhiteListingServiceTargets(context));
- final AccessibilityManager ams = context.getSystemService(AccessibilityManager.class);
- final List<String> requiredTargets = ams.getAccessibilityShortcutTargets(shortcutType);
- targets.removeIf(target -> !requiredTargets.contains(target.getId()));
-
return targets;
}
@@ -249,21 +258,21 @@ public class AccessibilityButtonChooserActivity extends Activity {
}
}
- private void disableService(String componentId) {
+ private void setServiceEnabled(String componentId, boolean enabled) {
if (isWhiteListingService(componentId)) {
- setWhiteListingServiceEnabled(componentId, /* settingsValueOff */ 0);
+ setWhiteListingServiceEnabled(componentId,
+ enabled ? /* settingsValueOn */ 1 : /* settingsValueOff */ 0);
} else {
final ComponentName componentName = ComponentName.unflattenFromString(componentId);
- setAccessibilityServiceState(this, componentName, /* enabled= */ false);
+ setAccessibilityServiceState(this, componentName, enabled);
}
}
private static class ViewHolder {
View mItemView;
+ CheckBox mCheckBox;
ImageView mIconView;
TextView mLabelView;
- FrameLayout mItemContainer;
- ImageView mActionViewItem;
Switch mSwitchItem;
}
@@ -314,13 +323,11 @@ public class AccessibilityButtonChooserActivity extends Activity {
false);
holder = new ViewHolder();
holder.mItemView = convertView;
+ holder.mCheckBox = convertView.findViewById(
+ R.id.accessibility_button_target_checkbox);
holder.mIconView = convertView.findViewById(R.id.accessibility_button_target_icon);
holder.mLabelView = convertView.findViewById(
R.id.accessibility_button_target_label);
- holder.mItemContainer = convertView.findViewById(
- R.id.accessibility_button_target_item_container);
- holder.mActionViewItem = convertView.findViewById(
- R.id.accessibility_button_target_view_item);
holder.mSwitchItem = convertView.findViewById(
R.id.accessibility_button_target_switch_item);
convertView.setTag(holder);
@@ -329,9 +336,6 @@ public class AccessibilityButtonChooserActivity extends Activity {
}
final AccessibilityButtonTarget target = mButtonTargets.get(position);
- holder.mIconView.setImageDrawable(target.getDrawable());
- holder.mLabelView.setText(target.getLabel());
-
updateActionItem(context, holder, target);
return convertView;
@@ -342,24 +346,24 @@ public class AccessibilityButtonChooserActivity extends Activity {
switch (target.getFragmentType()) {
case AccessibilityServiceFragmentType.LEGACY:
- updateLegacyActionItemVisibility(context, holder);
+ updateLegacyActionItemVisibility(holder, target);
break;
case AccessibilityServiceFragmentType.INVISIBLE:
- updateInvisibleActionItemVisibility(context, holder);
+ updateInvisibleActionItemVisibility(holder, target);
break;
case AccessibilityServiceFragmentType.INTUITIVE:
updateIntuitiveActionItemVisibility(context, holder, target);
break;
case AccessibilityServiceFragmentType.BOUNCE:
- updateBounceActionItemVisibility(context, holder);
+ updateBounceActionItemVisibility(holder, target);
break;
default:
throw new IllegalStateException("Unexpected fragment type");
}
}
- private void updateLegacyActionItemVisibility(@NonNull Context context,
- @NonNull ViewHolder holder) {
+ private void updateLegacyActionItemVisibility(@NonNull ViewHolder holder,
+ AccessibilityButtonTarget target) {
final boolean isLaunchMenuMode = (mShortcutMenuMode == ShortcutMenuMode.LAUNCH);
final boolean isHardwareButtonTriggered =
(mShortcutButtonType == ACCESSIBILITY_SHORTCUT_KEY);
@@ -367,31 +371,42 @@ public class AccessibilityButtonChooserActivity extends Activity {
final ColorMatrix grayScaleMatrix = new ColorMatrix();
grayScaleMatrix.setSaturation(/* grayScale */0);
+ holder.mCheckBox.setChecked(!isLaunchMenuMode && target.isChecked());
+ holder.mCheckBox.setEnabled(enabledState);
+ holder.mCheckBox.setVisibility(isLaunchMenuMode ? View.GONE : View.VISIBLE);
+
+ holder.mIconView.setImageDrawable(target.getDrawable());
holder.mIconView.setColorFilter(enabledState
? null : new ColorMatrixColorFilter(grayScaleMatrix));
holder.mIconView.setAlpha(enabledState
? ENABLED_ALPHA : DISABLED_ALPHA);
+
+ holder.mLabelView.setText(target.getLabel());
holder.mLabelView.setEnabled(enabledState);
- holder.mActionViewItem.setEnabled(enabledState);
- holder.mActionViewItem.setImageDrawable(context.getDrawable(R.drawable.ic_delete_item));
- holder.mActionViewItem.setVisibility(View.VISIBLE);
+
holder.mSwitchItem.setVisibility(View.GONE);
- holder.mItemContainer.setVisibility(isLaunchMenuMode ? View.GONE : View.VISIBLE);
+
holder.mItemView.setEnabled(enabledState);
holder.mItemView.setClickable(!enabledState);
}
- private void updateInvisibleActionItemVisibility(@NonNull Context context,
- @NonNull ViewHolder holder) {
+ private void updateInvisibleActionItemVisibility(@NonNull ViewHolder holder,
+ AccessibilityButtonTarget target) {
+ final boolean isEditMenuMode = (mShortcutMenuMode == ShortcutMenuMode.EDIT);
+
+ holder.mCheckBox.setChecked(isEditMenuMode && target.isChecked());
+ holder.mCheckBox.setEnabled(true);
+ holder.mCheckBox.setVisibility(isEditMenuMode ? View.VISIBLE : View.GONE);
+
holder.mIconView.setColorFilter(null);
holder.mIconView.setAlpha(ENABLED_ALPHA);
+ holder.mIconView.setImageDrawable(target.getDrawable());
+
+ holder.mLabelView.setText(target.getLabel());
holder.mLabelView.setEnabled(true);
- holder.mActionViewItem.setEnabled(true);
- holder.mActionViewItem.setImageDrawable(context.getDrawable(R.drawable.ic_delete_item));
- holder.mActionViewItem.setVisibility(View.VISIBLE);
+
holder.mSwitchItem.setVisibility(View.GONE);
- holder.mItemContainer.setVisibility((mShortcutMenuMode == ShortcutMenuMode.EDIT)
- ? View.VISIBLE : View.GONE);
+
holder.mItemView.setEnabled(true);
holder.mItemView.setClickable(false);
}
@@ -403,30 +418,41 @@ public class AccessibilityButtonChooserActivity extends Activity {
? isWhiteListingServiceEnabled(context, target)
: isAccessibilityServiceEnabled(context, target);
+ holder.mCheckBox.setChecked(isEditMenuMode && target.isChecked());
+ holder.mCheckBox.setEnabled(true);
+ holder.mCheckBox.setVisibility(isEditMenuMode ? View.VISIBLE : View.GONE);
+
holder.mIconView.setColorFilter(null);
holder.mIconView.setAlpha(ENABLED_ALPHA);
+ holder.mIconView.setImageDrawable(target.getDrawable());
+
+ holder.mLabelView.setText(target.getLabel());
holder.mLabelView.setEnabled(true);
- holder.mActionViewItem.setEnabled(true);
- holder.mActionViewItem.setImageDrawable(context.getDrawable(R.drawable.ic_delete_item));
- holder.mActionViewItem.setVisibility(isEditMenuMode ? View.VISIBLE : View.GONE);
+
holder.mSwitchItem.setVisibility(isEditMenuMode ? View.GONE : View.VISIBLE);
holder.mSwitchItem.setChecked(!isEditMenuMode && isServiceEnabled);
- holder.mItemContainer.setVisibility(View.VISIBLE);
+
holder.mItemView.setEnabled(true);
holder.mItemView.setClickable(false);
}
- private void updateBounceActionItemVisibility(@NonNull Context context,
- @NonNull ViewHolder holder) {
+ private void updateBounceActionItemVisibility(@NonNull ViewHolder holder,
+ AccessibilityButtonTarget target) {
+ final boolean isEditMenuMode = (mShortcutMenuMode == ShortcutMenuMode.EDIT);
+
+ holder.mCheckBox.setChecked(isEditMenuMode && target.isChecked());
+ holder.mCheckBox.setEnabled(true);
+ holder.mCheckBox.setVisibility(isEditMenuMode ? View.VISIBLE : View.GONE);
+
holder.mIconView.setColorFilter(null);
holder.mIconView.setAlpha(ENABLED_ALPHA);
+ holder.mIconView.setImageDrawable(target.getDrawable());
+
+ holder.mLabelView.setText(target.getLabel());
holder.mLabelView.setEnabled(true);
- holder.mActionViewItem.setEnabled(true);
- holder.mActionViewItem.setImageDrawable(context.getDrawable(R.drawable.ic_delete_item));
- holder.mActionViewItem.setVisibility((mShortcutMenuMode == ShortcutMenuMode.EDIT)
- ? View.VISIBLE : View.GONE);
+
holder.mSwitchItem.setVisibility(View.GONE);
- holder.mItemContainer.setVisibility(View.VISIBLE);
+
holder.mItemView.setEnabled(true);
holder.mItemView.setClickable(false);
}
@@ -434,6 +460,9 @@ public class AccessibilityButtonChooserActivity extends Activity {
private static class AccessibilityButtonTarget {
private String mId;
+ @TargetType
+ private int mType;
+ private boolean mChecked;
private CharSequence mLabel;
private Drawable mDrawable;
@AccessibilityServiceFragmentType
@@ -442,6 +471,8 @@ public class AccessibilityButtonChooserActivity extends Activity {
AccessibilityButtonTarget(@NonNull Context context,
@NonNull AccessibilityServiceInfo serviceInfo) {
this.mId = serviceInfo.getComponentName().flattenToString();
+ this.mType = TargetType.ACCESSIBILITY_SERVICE;
+ this.mChecked = isTargetShortcutUsed(context, mId);
this.mLabel = serviceInfo.getResolveInfo().loadLabel(context.getPackageManager());
this.mDrawable = serviceInfo.getResolveInfo().loadIcon(context.getPackageManager());
this.mFragmentType = getAccessibilityServiceFragmentType(serviceInfo);
@@ -450,6 +481,8 @@ public class AccessibilityButtonChooserActivity extends Activity {
AccessibilityButtonTarget(@NonNull Context context,
@NonNull AccessibilityShortcutInfo shortcutInfo) {
this.mId = shortcutInfo.getComponentName().flattenToString();
+ this.mType = TargetType.ACCESSIBILITY_ACTIVITY;
+ this.mChecked = isTargetShortcutUsed(context, mId);
this.mLabel = shortcutInfo.getActivityInfo().loadLabel(context.getPackageManager());
this.mDrawable = shortcutInfo.getActivityInfo().loadIcon(context.getPackageManager());
this.mFragmentType = AccessibilityServiceFragmentType.BOUNCE;
@@ -458,15 +491,29 @@ public class AccessibilityButtonChooserActivity extends Activity {
AccessibilityButtonTarget(Context context, @NonNull String id, int labelResId,
int iconRes, @AccessibilityServiceFragmentType int fragmentType) {
this.mId = id;
+ this.mType = TargetType.WHITE_LISTING;
+ this.mChecked = isTargetShortcutUsed(context, mId);
this.mLabel = context.getText(labelResId);
this.mDrawable = context.getDrawable(iconRes);
this.mFragmentType = fragmentType;
}
+ public void setChecked(boolean checked) {
+ mChecked = checked;
+ }
+
public String getId() {
return mId;
}
+ public int getType() {
+ return mType;
+ }
+
+ public boolean isChecked() {
+ return mChecked;
+ }
+
public CharSequence getLabel() {
return mLabel;
}
@@ -519,19 +566,19 @@ public class AccessibilityButtonChooserActivity extends Activity {
}
private void onLegacyTargetSelected(AccessibilityButtonTarget target) {
- if (mShortcutType == ACCESSIBILITY_BUTTON) {
+ if (sShortcutType == ACCESSIBILITY_BUTTON) {
final AccessibilityManager ams = getSystemService(AccessibilityManager.class);
ams.notifyAccessibilityButtonClicked(getDisplayId(), target.getId());
- } else if (mShortcutType == ACCESSIBILITY_SHORTCUT_KEY) {
+ } else if (sShortcutType == ACCESSIBILITY_SHORTCUT_KEY) {
switchServiceState(target);
}
}
private void onInvisibleTargetSelected(AccessibilityButtonTarget target) {
final AccessibilityManager ams = getSystemService(AccessibilityManager.class);
- if (mShortcutType == ACCESSIBILITY_BUTTON) {
+ if (sShortcutType == ACCESSIBILITY_BUTTON) {
ams.notifyAccessibilityButtonClicked(getDisplayId(), target.getId());
- } else if (mShortcutType == ACCESSIBILITY_SHORTCUT_KEY) {
+ } else if (sShortcutType == ACCESSIBILITY_SHORTCUT_KEY) {
ams.performAccessibilityShortcut(target.getId());
}
}
@@ -542,9 +589,9 @@ public class AccessibilityButtonChooserActivity extends Activity {
private void onBounceTargetSelected(AccessibilityButtonTarget target) {
final AccessibilityManager ams = getSystemService(AccessibilityManager.class);
- if (mShortcutType == ACCESSIBILITY_BUTTON) {
+ if (sShortcutType == ACCESSIBILITY_BUTTON) {
ams.notifyAccessibilityButtonClicked(getDisplayId(), target.getId());
- } else if (mShortcutType == ACCESSIBILITY_SHORTCUT_KEY) {
+ } else if (sShortcutType == ACCESSIBILITY_SHORTCUT_KEY) {
ams.performAccessibilityShortcut(target.getId());
}
}
@@ -565,66 +612,72 @@ public class AccessibilityButtonChooserActivity extends Activity {
}
}
- private void onTargetDeleted(AdapterView<?> parent, View view, int position, long id) {
- final AccessibilityButtonTarget target = mTargets.get(position);
- final String componentId = target.getId();
+ private void onTargetChecked(AdapterView<?> parent, View view, int position, long id) {
+ mCurrentCheckedTarget = mTargets.get(position);
+ onTargetChecked(mCurrentCheckedTarget, !mCurrentCheckedTarget.isChecked());
+ }
+ private void onTargetChecked(AccessibilityButtonTarget target, boolean checked) {
switch (target.getFragmentType()) {
case AccessibilityServiceFragmentType.LEGACY:
- onLegacyTargetDeleted(position, componentId);
+ onLegacyTargetChecked(checked);
break;
case AccessibilityServiceFragmentType.INVISIBLE:
- onInvisibleTargetDeleted(position, componentId);
+ onInvisibleTargetChecked(checked);
break;
case AccessibilityServiceFragmentType.INTUITIVE:
- onIntuitiveTargetDeleted(position, componentId);
+ onIntuitiveTargetChecked(checked);
break;
case AccessibilityServiceFragmentType.BOUNCE:
- onBounceTargetDeleted(position, componentId);
+ onBounceTargetChecked(checked);
break;
default:
throw new IllegalStateException("Unexpected fragment type");
}
-
- if (mTargets.isEmpty()) {
- mAlertDialog.dismiss();
- }
}
- private void onLegacyTargetDeleted(int position, String componentId) {
- if (mShortcutType == ACCESSIBILITY_SHORTCUT_KEY) {
- optOutValueFromSettings(this, mShortcutUserType, componentId);
-
- mTargets.remove(position);
+ private void onLegacyTargetChecked(boolean checked) {
+ if (sShortcutType == ACCESSIBILITY_SHORTCUT_KEY) {
+ updateValueToSettings(mCurrentCheckedTarget.getId(), checked);
+ mCurrentCheckedTarget.setChecked(checked);
mTargetAdapter.notifyDataSetChanged();
}
}
- private void onInvisibleTargetDeleted(int position, String componentId) {
- optOutValueFromSettings(this, mShortcutUserType, componentId);
-
+ private void onInvisibleTargetChecked(boolean checked) {
final int shortcutTypes = UserShortcutType.SOFTWARE | UserShortcutType.HARDWARE;
- if (!hasValuesInSettings(this, shortcutTypes, componentId)) {
- disableService(componentId);
+ if (!hasValuesInSettings(this, shortcutTypes, mCurrentCheckedTarget.getId())) {
+ setServiceEnabled(mCurrentCheckedTarget.getId(), checked);
}
- mTargets.remove(position);
+ updateValueToSettings(mCurrentCheckedTarget.getId(), checked);
+ mCurrentCheckedTarget.setChecked(checked);
mTargetAdapter.notifyDataSetChanged();
}
- private void onIntuitiveTargetDeleted(int position, String componentId) {
- optOutValueFromSettings(this, mShortcutUserType, componentId);
- mTargets.remove(position);
+ private void onIntuitiveTargetChecked(boolean checked) {
+ updateValueToSettings(mCurrentCheckedTarget.getId(), checked);
+ mCurrentCheckedTarget.setChecked(checked);
mTargetAdapter.notifyDataSetChanged();
}
- private void onBounceTargetDeleted(int position, String componentId) {
- optOutValueFromSettings(this, mShortcutUserType, componentId);
- mTargets.remove(position);
+ private void onBounceTargetChecked(boolean checked) {
+ updateValueToSettings(mCurrentCheckedTarget.getId(), checked);
+ mCurrentCheckedTarget.setChecked(checked);
mTargetAdapter.notifyDataSetChanged();
}
- private void onCancelButtonClicked() {
+ private void updateValueToSettings(String componentId, boolean checked) {
+ if (checked) {
+ optInValueToSettings(this, mShortcutUserType, componentId);
+ } else {
+ optOutValueFromSettings(this, mShortcutUserType, componentId);
+ }
+ }
+
+ private void onDoneButtonClicked() {
+ mTargets.clear();
+ mTargets.addAll(getServiceTargets(this, sShortcutType));
mTargetAdapter.setShortcutMenuMode(ShortcutMenuMode.LAUNCH);
mTargetAdapter.notifyDataSetChanged();
@@ -635,11 +688,13 @@ public class AccessibilityButtonChooserActivity extends Activity {
}
private void onEditButtonClicked() {
+ mTargets.clear();
+ mTargets.addAll(getInstalledServiceTargets(this));
mTargetAdapter.setShortcutMenuMode(ShortcutMenuMode.EDIT);
mTargetAdapter.notifyDataSetChanged();
mAlertDialog.getButton(DialogInterface.BUTTON_POSITIVE).setText(
- getString(R.string.cancel_accessibility_shortcut_menu_button));
+ getString(R.string.done_accessibility_shortcut_menu_button));
updateDialogListeners();
}
@@ -649,15 +704,20 @@ public class AccessibilityButtonChooserActivity extends Activity {
(mTargetAdapter.getShortcutMenuMode() == ShortcutMenuMode.EDIT);
final int selectDialogTitleId = R.string.accessibility_select_shortcut_menu_title;
final int editDialogTitleId =
- (mShortcutType == ACCESSIBILITY_BUTTON)
+ (sShortcutType == ACCESSIBILITY_BUTTON)
? R.string.accessibility_edit_shortcut_menu_button_title
: R.string.accessibility_edit_shortcut_menu_volume_title;
mAlertDialog.setTitle(getString(isEditMenuMode ? editDialogTitleId : selectDialogTitleId));
-
mAlertDialog.getButton(DialogInterface.BUTTON_POSITIVE).setOnClickListener(
- isEditMenuMode ? view -> onCancelButtonClicked() : view -> onEditButtonClicked());
+ isEditMenuMode ? view -> onDoneButtonClicked() : view -> onEditButtonClicked());
mAlertDialog.getListView().setOnItemClickListener(
- isEditMenuMode ? this::onTargetDeleted : this::onTargetSelected);
+ isEditMenuMode ? this::onTargetChecked : this::onTargetSelected);
+ }
+
+ private static boolean isTargetShortcutUsed(@NonNull Context context, String id) {
+ final AccessibilityManager ams = context.getSystemService(AccessibilityManager.class);
+ final List<String> requiredTargets = ams.getAccessibilityShortcutTargets(sShortcutType);
+ return requiredTargets.contains(id);
}
}
diff --git a/core/res/res/layout/accessibility_button_chooser_item.xml b/core/res/res/layout/accessibility_button_chooser_item.xml
index c01766b2c748..b7dd892fd161 100644
--- a/core/res/res/layout/accessibility_button_chooser_item.xml
+++ b/core/res/res/layout/accessibility_button_chooser_item.xml
@@ -21,10 +21,17 @@
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
- android:paddingStart="16dp"
- android:paddingEnd="16dp"
- android:paddingTop="12dp"
- android:paddingBottom="12dp">
+ android:padding="16dp">
+
+ <CheckBox
+ android:id="@+id/accessibility_button_target_checkbox"
+ android:layout_width="wrap_content"
+ android:layout_height="wrap_content"
+ android:paddingStart="16dp"
+ android:background="@null"
+ android:clickable="false"
+ android:focusable="false"
+ android:visibility="gone"/>
<ImageView
android:id="@+id/accessibility_button_target_icon"
@@ -36,31 +43,18 @@
android:id="@+id/accessibility_button_target_label"
android:layout_width="0dp"
android:layout_height="wrap_content"
- android:layout_marginStart="14dp"
+ android:layout_marginStart="16dp"
android:layout_weight="1"
android:textSize="20sp"
android:textColor="?attr/textColorPrimary"
android:fontFamily="sans-serif-medium"/>
- <FrameLayout
- android:id="@+id/accessibility_button_target_item_container"
+ <Switch
+ android:id="@+id/accessibility_button_target_switch_item"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
- android:minWidth="56dp">
-
- <ImageView
- android:id="@+id/accessibility_button_target_view_item"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_gravity="center"/>
-
- <Switch android:id="@+id/accessibility_button_target_switch_item"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_gravity="center"
- android:background="@null"
- android:clickable="false"
- android:focusable="false"/>
- </FrameLayout>
+ android:background="@null"
+ android:clickable="false"
+ android:focusable="false"/>
</LinearLayout>
diff --git a/core/res/res/values/strings.xml b/core/res/res/values/strings.xml
index addcd81ae5c8..a623cc834361 100644
--- a/core/res/res/values/strings.xml
+++ b/core/res/res/values/strings.xml
@@ -4422,8 +4422,8 @@
any service item in the menu list. [CHAR LIMIT=100] -->
<string name="edit_accessibility_shortcut_menu_button">Edit shortcuts</string>
- <!-- Text in button that cancel the accessibility shortcut menu changed status. [CHAR LIMIT=100] -->
- <string name="cancel_accessibility_shortcut_menu_button">Cancel</string>
+ <!-- Text in button that complete the accessibility shortcut menu changed status. [CHAR LIMIT=100] -->
+ <string name="done_accessibility_shortcut_menu_button">Done</string>
<!-- Text in button that turns off the accessibility shortcut -->
<string name="disable_accessibility_shortcut">Turn off Shortcut</string>
diff --git a/core/res/res/values/symbols.xml b/core/res/res/values/symbols.xml
index 0971aadfe4ab..5f0db15ec858 100644
--- a/core/res/res/values/symbols.xml
+++ b/core/res/res/values/symbols.xml
@@ -3243,14 +3243,13 @@
<!-- Accessibility Button -->
<java-symbol type="layout" name="accessibility_button_chooser_item" />
+ <java-symbol type="id" name="accessibility_button_target_checkbox" />
<java-symbol type="id" name="accessibility_button_target_icon" />
<java-symbol type="id" name="accessibility_button_target_label" />
- <java-symbol type="id" name="accessibility_button_target_item_container" />
- <java-symbol type="id" name="accessibility_button_target_view_item" />
<java-symbol type="id" name="accessibility_button_target_switch_item" />
<java-symbol type="string" name="accessibility_magnification_chooser_text" />
<java-symbol type="string" name="edit_accessibility_shortcut_menu_button" />
- <java-symbol type="string" name="cancel_accessibility_shortcut_menu_button" />
+ <java-symbol type="string" name="done_accessibility_shortcut_menu_button" />
<java-symbol type="drawable" name="ic_accessibility_color_inversion" />
<java-symbol type="drawable" name="ic_accessibility_color_correction" />