Merge \"Added dismiss, expand, and collapse accessibility actions\" into nyc-dev
am: c1720dce1b
Change-Id: I14674254eb79fef58e4dcb1a8d7ecaab24831691
This commit is contained in:
@@ -22,6 +22,7 @@ import android.graphics.Canvas;
|
||||
import android.graphics.Outline;
|
||||
import android.graphics.Rect;
|
||||
import android.graphics.drawable.Drawable;
|
||||
import android.os.Bundle;
|
||||
import android.util.AttributeSet;
|
||||
import android.view.accessibility.AccessibilityNodeInfo;
|
||||
import android.widget.ImageView;
|
||||
@@ -63,6 +64,33 @@ public class NotificationHeaderView extends ViewGroup {
|
||||
}
|
||||
}
|
||||
};
|
||||
final AccessibilityDelegate mExpandDelegate = new AccessibilityDelegate() {
|
||||
|
||||
@Override
|
||||
public boolean performAccessibilityAction(View host, int action, Bundle args) {
|
||||
if (super.performAccessibilityAction(host, action, args)) {
|
||||
return true;
|
||||
}
|
||||
if (action == AccessibilityNodeInfo.ACTION_COLLAPSE
|
||||
|| action == AccessibilityNodeInfo.ACTION_EXPAND) {
|
||||
mExpandClickListener.onClick(mExpandButton);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onInitializeAccessibilityNodeInfo(View host, AccessibilityNodeInfo info) {
|
||||
super.onInitializeAccessibilityNodeInfo(host, info);
|
||||
// Avoid that the button description is also spoken
|
||||
info.setClassName(getClass().getName());
|
||||
if (mExpanded) {
|
||||
info.addAction(AccessibilityNodeInfo.AccessibilityAction.ACTION_COLLAPSE);
|
||||
} else {
|
||||
info.addAction(AccessibilityNodeInfo.AccessibilityAction.ACTION_EXPAND);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
public NotificationHeaderView(Context context) {
|
||||
this(context, null);
|
||||
@@ -92,6 +120,9 @@ public class NotificationHeaderView extends ViewGroup {
|
||||
mAppName = findViewById(com.android.internal.R.id.app_name_text);
|
||||
mHeaderText = findViewById(com.android.internal.R.id.header_text);
|
||||
mExpandButton = (ImageView) findViewById(com.android.internal.R.id.expand_button);
|
||||
if (mExpandButton != null) {
|
||||
mExpandButton.setAccessibilityDelegate(mExpandDelegate);
|
||||
}
|
||||
mIcon = findViewById(com.android.internal.R.id.icon);
|
||||
mProfileBadge = findViewById(com.android.internal.R.id.profile_badge);
|
||||
}
|
||||
@@ -230,7 +261,7 @@ public class NotificationHeaderView extends ViewGroup {
|
||||
public void setOnClickListener(@Nullable OnClickListener l) {
|
||||
mExpandClickListener = l;
|
||||
setOnTouchListener(mExpandClickListener != null ? mTouchListener : null);
|
||||
setFocusable(l != null);
|
||||
mExpandButton.setOnClickListener(mExpandClickListener);
|
||||
updateTouchListener();
|
||||
}
|
||||
|
||||
@@ -380,19 +411,6 @@ public class NotificationHeaderView extends ViewGroup {
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onInitializeAccessibilityNodeInfo(AccessibilityNodeInfo info) {
|
||||
super.onInitializeAccessibilityNodeInfo(info);
|
||||
if (mExpandClickListener != null) {
|
||||
AccessibilityNodeInfo.AccessibilityAction expand
|
||||
= new AccessibilityNodeInfo.AccessibilityAction(
|
||||
AccessibilityNodeInfo.ACTION_CLICK,
|
||||
getContext().getString(
|
||||
com.android.internal.R.string.expand_action_accessibility));
|
||||
info.addAction(expand);
|
||||
}
|
||||
}
|
||||
|
||||
public ImageView getExpandButton() {
|
||||
return mExpandButton;
|
||||
}
|
||||
|
||||
@@ -0,0 +1,62 @@
|
||||
/*
|
||||
* Copyright (C) 2016 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.widget;
|
||||
|
||||
import android.annotation.Nullable;
|
||||
import android.content.Context;
|
||||
import android.graphics.Rect;
|
||||
import android.util.AttributeSet;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.RemoteViews;
|
||||
|
||||
/**
|
||||
* An expand button in a notification
|
||||
*/
|
||||
@RemoteViews.RemoteView
|
||||
public class NotificationExpandButton extends ImageView {
|
||||
public NotificationExpandButton(Context context) {
|
||||
super(context);
|
||||
}
|
||||
|
||||
public NotificationExpandButton(Context context, @Nullable AttributeSet attrs) {
|
||||
super(context, attrs);
|
||||
}
|
||||
|
||||
public NotificationExpandButton(Context context, @Nullable AttributeSet attrs,
|
||||
int defStyleAttr) {
|
||||
super(context, attrs, defStyleAttr);
|
||||
}
|
||||
|
||||
public NotificationExpandButton(Context context, @Nullable AttributeSet attrs, int defStyleAttr,
|
||||
int defStyleRes) {
|
||||
super(context, attrs, defStyleAttr, defStyleRes);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void getBoundsOnScreen(Rect outRect, boolean clipToParent) {
|
||||
super.getBoundsOnScreen(outRect, clipToParent);
|
||||
extendRectToMinTouchSize(outRect);
|
||||
}
|
||||
|
||||
private void extendRectToMinTouchSize(Rect rect) {
|
||||
int touchTargetSize = (int) (getResources().getDisplayMetrics().density * 48);
|
||||
rect.left = rect.centerX() - touchTargetSize / 2;
|
||||
rect.right = rect.left + touchTargetSize;
|
||||
rect.top = rect.centerY() - touchTargetSize / 2;
|
||||
rect.bottom = rect.top + touchTargetSize;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user