Rollback chooser menu to version Q behavior for accessibility button (1/n). am: b8bf55c8c0
Change-Id: I1cd26352784fe16108dd5c9d39eacea0ef53ce49
This commit is contained in:
@@ -0,0 +1,102 @@
|
||||
/*
|
||||
* Copyright (C) 2020 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.internal.accessibility.dialog;
|
||||
|
||||
import static android.view.WindowManagerPolicyConstants.NAV_BAR_MODE_GESTURAL;
|
||||
import static android.view.accessibility.AccessibilityManager.ACCESSIBILITY_BUTTON;
|
||||
import static android.view.accessibility.AccessibilityManager.ACCESSIBILITY_SHORTCUT_KEY;
|
||||
|
||||
import static com.android.internal.accessibility.dialog.AccessibilityTargetHelper.getTargets;
|
||||
import static com.android.internal.util.Preconditions.checkArgument;
|
||||
|
||||
import android.annotation.Nullable;
|
||||
import android.app.Activity;
|
||||
import android.os.Bundle;
|
||||
import android.provider.Settings;
|
||||
import android.text.TextUtils;
|
||||
import android.view.View;
|
||||
import android.view.accessibility.AccessibilityManager;
|
||||
import android.widget.GridView;
|
||||
import android.widget.TextView;
|
||||
|
||||
import com.android.internal.R;
|
||||
import com.android.internal.widget.ResolverDrawerLayout;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Activity used to display and persist a service or feature target for the Accessibility button.
|
||||
*/
|
||||
public class AccessibilityButtonChooserActivity extends Activity {
|
||||
private final List<AccessibilityTarget> mTargets = new ArrayList<>();
|
||||
|
||||
@Override
|
||||
protected void onCreate(@Nullable Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
setContentView(R.layout.accessibility_button_chooser);
|
||||
|
||||
final int shortcutType = getIntent().getIntExtra(AccessibilityManager.EXTRA_SHORTCUT_TYPE,
|
||||
/* unexpectedShortcutType */ -1);
|
||||
final boolean existInShortcutType = (shortcutType == ACCESSIBILITY_BUTTON)
|
||||
|| (shortcutType == ACCESSIBILITY_SHORTCUT_KEY);
|
||||
checkArgument(existInShortcutType, "Unexpected shortcut type: " + shortcutType);
|
||||
|
||||
final ResolverDrawerLayout rdl = findViewById(R.id.contentPanel);
|
||||
if (rdl != null) {
|
||||
rdl.setOnDismissedListener(this::finish);
|
||||
}
|
||||
|
||||
final String component = Settings.Secure.getString(getContentResolver(),
|
||||
Settings.Secure.ACCESSIBILITY_BUTTON_TARGET_COMPONENT);
|
||||
|
||||
final AccessibilityManager accessibilityManager =
|
||||
getSystemService(AccessibilityManager.class);
|
||||
final boolean isTouchExploreOn =
|
||||
accessibilityManager.isTouchExplorationEnabled();
|
||||
final boolean isGestureNavigateEnabled =
|
||||
NAV_BAR_MODE_GESTURAL == getResources().getInteger(
|
||||
com.android.internal.R.integer.config_navBarInteractionMode);
|
||||
|
||||
if (isGestureNavigateEnabled) {
|
||||
final TextView promptPrologue = findViewById(R.id.accessibility_button_prompt_prologue);
|
||||
promptPrologue.setText(isTouchExploreOn
|
||||
? R.string.accessibility_gesture_3finger_prompt_text
|
||||
: R.string.accessibility_gesture_prompt_text);
|
||||
}
|
||||
|
||||
if (TextUtils.isEmpty(component)) {
|
||||
final TextView prompt = findViewById(R.id.accessibility_button_prompt);
|
||||
if (isGestureNavigateEnabled) {
|
||||
prompt.setText(isTouchExploreOn
|
||||
? R.string.accessibility_gesture_3finger_instructional_text
|
||||
: R.string.accessibility_gesture_instructional_text);
|
||||
}
|
||||
prompt.setVisibility(View.VISIBLE);
|
||||
}
|
||||
|
||||
mTargets.addAll(getTargets(this, shortcutType));
|
||||
|
||||
final GridView gridview = findViewById(R.id.accessibility_button_chooser_grid);
|
||||
gridview.setAdapter(new ButtonTargetAdapter(mTargets));
|
||||
gridview.setOnItemClickListener((parent, view, position, id) -> {
|
||||
final String key = Settings.Secure.ACCESSIBILITY_BUTTON_TARGET_COMPONENT;
|
||||
Settings.Secure.putString(getContentResolver(), key, mTargets.get(position).getId());
|
||||
finish();
|
||||
});
|
||||
}
|
||||
}
|
||||
@@ -149,10 +149,10 @@ public class AccessibilityShortcutChooserActivity extends Activity {
|
||||
|
||||
private void updateDialogListeners() {
|
||||
final boolean isEditMenuMode =
|
||||
(mTargetAdapter.getShortcutMenuMode() == ShortcutMenuMode.EDIT);
|
||||
mTargetAdapter.getShortcutMenuMode() == ShortcutMenuMode.EDIT;
|
||||
final int selectDialogTitleId = R.string.accessibility_select_shortcut_menu_title;
|
||||
final int editDialogTitleId =
|
||||
(mShortcutType == ACCESSIBILITY_BUTTON)
|
||||
mShortcutType == ACCESSIBILITY_BUTTON
|
||||
? R.string.accessibility_edit_shortcut_menu_button_title
|
||||
: R.string.accessibility_edit_shortcut_menu_volume_title;
|
||||
|
||||
|
||||
@@ -0,0 +1,68 @@
|
||||
/*
|
||||
* Copyright (C) 2020 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.internal.accessibility.dialog;
|
||||
|
||||
import android.content.Context;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.TextView;
|
||||
|
||||
import com.android.internal.R;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Extension for {@link TargetAdapter} and used for AccessibilityButtonChooserActivity.
|
||||
*/
|
||||
class ButtonTargetAdapter extends TargetAdapter {
|
||||
private List<AccessibilityTarget> mTargets;
|
||||
|
||||
ButtonTargetAdapter(List<AccessibilityTarget> targets) {
|
||||
mTargets = targets;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getCount() {
|
||||
return mTargets.size();
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object getItem(int position) {
|
||||
return mTargets.get(position);
|
||||
}
|
||||
|
||||
@Override
|
||||
public long getItemId(int position) {
|
||||
return position;
|
||||
}
|
||||
|
||||
@Override
|
||||
public View getView(int position, View convertView, ViewGroup parent) {
|
||||
final Context context = parent.getContext();
|
||||
final View root = LayoutInflater.from(context).inflate(
|
||||
R.layout.accessibility_button_chooser_item, parent, /* attachToRoot= */
|
||||
false);
|
||||
final AccessibilityTarget target = mTargets.get(position);
|
||||
final ImageView iconView = root.findViewById(R.id.accessibility_button_target_icon);
|
||||
final TextView labelView = root.findViewById(R.id.accessibility_button_target_label);
|
||||
iconView.setImageDrawable(target.getIcon());
|
||||
labelView.setText(target.getLabel());
|
||||
return root;
|
||||
}
|
||||
}
|
||||
@@ -151,7 +151,7 @@ public final class ShortcutUtils {
|
||||
public static String convertToKey(@UserShortcutType int type) {
|
||||
switch (type) {
|
||||
case UserShortcutType.SOFTWARE:
|
||||
return Settings.Secure.ACCESSIBILITY_BUTTON_TARGET_COMPONENT;
|
||||
return Settings.Secure.ACCESSIBILITY_BUTTON_TARGETS;
|
||||
case UserShortcutType.HARDWARE:
|
||||
return Settings.Secure.ACCESSIBILITY_SHORTCUT_TARGET_SERVICE;
|
||||
case UserShortcutType.TRIPLETAP:
|
||||
|
||||
@@ -5072,6 +5072,20 @@
|
||||
android:configChanges="screenSize|smallestScreenSize|screenLayout|orientation|keyboard|keyboardHidden"
|
||||
android:process=":ui"
|
||||
android:visibleToInstantApps="true">
|
||||
<intent-filter>
|
||||
<category android:name="android.intent.category.DEFAULT" />
|
||||
</intent-filter>
|
||||
</activity>
|
||||
<activity android:name="com.android.internal.accessibility.dialog.AccessibilityButtonChooserActivity"
|
||||
android:exported="false"
|
||||
android:theme="@style/Theme.DeviceDefault.Resolver"
|
||||
android:finishOnCloseSystemDialogs="true"
|
||||
android:excludeFromRecents="true"
|
||||
android:documentLaunchMode="never"
|
||||
android:relinquishTaskIdentity="true"
|
||||
android:configChanges="screenSize|smallestScreenSize|screenLayout|orientation|keyboard|keyboardHidden"
|
||||
android:process=":ui"
|
||||
android:visibleToInstantApps="true">
|
||||
<intent-filter>
|
||||
<action android:name="com.android.internal.intent.action.CHOOSE_ACCESSIBILITY_BUTTON" />
|
||||
<category android:name="android.intent.category.DEFAULT" />
|
||||
|
||||
72
core/res/res/layout/accessibility_button_chooser.xml
Normal file
72
core/res/res/layout/accessibility_button_chooser.xml
Normal file
@@ -0,0 +1,72 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!--
|
||||
Copyright (C) 2020 The Android Open Source Project
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
-->
|
||||
|
||||
<com.android.internal.widget.ResolverDrawerLayout
|
||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:maxWidth="@dimen/resolver_max_width"
|
||||
android:maxCollapsedHeight="256dp"
|
||||
android:maxCollapsedHeightSmall="56dp"
|
||||
android:id="@id/contentPanel">
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alwaysShow="true"
|
||||
android:orientation="vertical"
|
||||
android:background="?attr/colorBackground"
|
||||
android:paddingTop="8dp"
|
||||
android:paddingBottom="8dp"
|
||||
android:paddingStart="?attr/dialogPreferredPadding"
|
||||
android:paddingEnd="?attr/dialogPreferredPadding">
|
||||
|
||||
<TextView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:minHeight="56dp"
|
||||
android:id="@+id/accessibility_button_prompt_prologue"
|
||||
android:textAppearance="?attr/textAppearanceMedium"
|
||||
android:text="@string/accessibility_button_prompt_text"
|
||||
android:gravity="start|center_vertical"
|
||||
android:layout_alignParentStart="true"
|
||||
android:paddingTop="8dp"
|
||||
android:paddingBottom="8dp"/>
|
||||
|
||||
<GridView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:id="@+id/accessibility_button_chooser_grid"
|
||||
android:columnWidth="90dp"
|
||||
android:numColumns="auto_fit"
|
||||
android:verticalSpacing="10dp"
|
||||
android:horizontalSpacing="10dp"
|
||||
android:stretchMode="columnWidth"
|
||||
android:gravity="center"/>
|
||||
|
||||
<TextView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:id="@+id/accessibility_button_prompt"
|
||||
android:textAppearance="?attr/textAppearanceMedium"
|
||||
android:text="@string/accessibility_button_instructional_text"
|
||||
android:gravity="start|center_vertical"
|
||||
android:paddingTop="8dp"
|
||||
android:paddingBottom="8dp"
|
||||
android:visibility="gone"/>
|
||||
</LinearLayout>
|
||||
</com.android.internal.widget.ResolverDrawerLayout>
|
||||
53
core/res/res/layout/accessibility_button_chooser_item.xml
Normal file
53
core/res/res/layout/accessibility_button_chooser_item.xml
Normal file
@@ -0,0 +1,53 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!--
|
||||
Copyright (C) 2020 The Android Open Source Project
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
-->
|
||||
|
||||
<LinearLayout
|
||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:orientation="vertical"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:minWidth="80dp"
|
||||
android:gravity="center"
|
||||
android:paddingTop="8dp"
|
||||
android:paddingBottom="8dp"
|
||||
android:background="?attr/selectableItemBackgroundBorderless">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/accessibility_button_target_icon"
|
||||
android:layout_width="48dp"
|
||||
android:layout_height="48dp"
|
||||
android:layout_marginLeft="3dp"
|
||||
android:layout_marginRight="3dp"
|
||||
android:layout_marginBottom="3dp"
|
||||
android:scaleType="fitCenter"/>
|
||||
|
||||
<TextView
|
||||
android:id="@+id/accessibility_button_target_label"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginTop="8dp"
|
||||
android:layout_marginLeft="4dp"
|
||||
android:layout_marginRight="4dp"
|
||||
android:textAppearance="?attr/textAppearanceSmall"
|
||||
android:textColor="?attr/textColorPrimary"
|
||||
android:textSize="12sp"
|
||||
android:fontFamily="sans-serif-condensed"
|
||||
android:gravity="top|center_horizontal"
|
||||
android:minLines="2"
|
||||
android:maxLines="2"
|
||||
android:ellipsize="marquee"/>
|
||||
</LinearLayout>
|
||||
@@ -3241,6 +3241,18 @@
|
||||
<java-symbol type="id" name="accessibility_shortcut_target_switch_item" />
|
||||
|
||||
<!-- Accessibility Button -->
|
||||
<java-symbol type="layout" name="accessibility_button_chooser" />
|
||||
<java-symbol type="layout" name="accessibility_button_chooser_item" />
|
||||
<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_chooser_grid" />
|
||||
<java-symbol type="id" name="accessibility_button_prompt" />
|
||||
<java-symbol type="id" name="accessibility_button_prompt_prologue" />
|
||||
<java-symbol type="string" name="accessibility_gesture_prompt_text" />
|
||||
<java-symbol type="string" name="accessibility_gesture_3finger_prompt_text" />
|
||||
<java-symbol type="string" name="accessibility_gesture_instructional_text" />
|
||||
<java-symbol type="string" name="accessibility_gesture_3finger_instructional_text" />
|
||||
|
||||
<java-symbol type="string" name="accessibility_magnification_chooser_text" />
|
||||
<java-symbol type="string" name="edit_accessibility_shortcut_menu_button" />
|
||||
<java-symbol type="string" name="done_accessibility_shortcut_menu_button" />
|
||||
|
||||
Reference in New Issue
Block a user