Merge "Fix content description for notification icons" into nyc-dev am: eefff37 am: 18a98c1

am: a04e33a

* commit 'a04e33a2dc2f0a2ac7b9966b3739d9142c1bd749':
  Fix content description for notification icons

Change-Id: Id2c9b4c5cd490254380c4a98ed65ef48fdbf91b9
This commit is contained in:
Adrian Roos
2016-04-23 01:56:46 +00:00
committed by android-build-merger
4 changed files with 21 additions and 7 deletions

View File

@@ -3301,7 +3301,10 @@ public class Notification implements Parcelable
}
}
private String loadHeaderAppName() {
/**
* @hide
*/
public String loadHeaderAppName() {
CharSequence name = null;
final PackageManager pm = mContext.getPackageManager();
if (mN.extras.containsKey(EXTRA_SUBSTITUTE_APP_NAME)) {

View File

@@ -1657,6 +1657,9 @@
<!-- Accessibility label for window when QS editing is happening [CHAR LIMIT=NONE] -->
<string name="accessibility_desc_quick_settings_edit">Quick settings editor.</string>
<!-- Accessibility label for the notification icons in the collapsed status bar. Not shown on screen [CHAR LIMIT=NONE] -->
<string name="accessibility_desc_notification_icon"><xliff:g name="app_name" example="Gmail">%1$s</xliff:g> notification: <xliff:g name="notification_text" example="5 new messages">%2$s</xliff:g></string>
<!-- Multi-Window strings -->
<!-- Text that gets shown on top of current activity to inform the user that the system force-resized the current activity and that things might crash/not work properly [CHAR LIMIT=NONE] -->
<string name="dock_forced_resizable">App may not work with split-screen.</string>

View File

@@ -2118,7 +2118,7 @@ public abstract class BaseStatusBar extends SystemUI implements
smallIcon,
n.iconLevel,
n.number,
n.tickerText);
StatusBarIconView.contentDescForNotification(mContext, n));
if (!iconView.set(ic)) {
handleNotificationError(sbn, "Couldn't create icon: " + ic);
return null;
@@ -2287,7 +2287,7 @@ public abstract class BaseStatusBar extends SystemUI implements
n.getSmallIcon(),
n.iconLevel,
n.number,
n.tickerText);
StatusBarIconView.contentDescForNotification(mContext, n));
entry.icon.setNotification(n);
if (!entry.icon.set(ic)) {
handleNotificationError(notification, "Couldn't update icon: " + ic);
@@ -2311,7 +2311,7 @@ public abstract class BaseStatusBar extends SystemUI implements
n.getSmallIcon(),
n.iconLevel,
n.number,
n.tickerText);
StatusBarIconView.contentDescForNotification(mContext, n));
entry.icon.setNotification(n);
entry.icon.set(ic);
inflateViews(entry, mStackScroller);

View File

@@ -307,9 +307,9 @@ public class StatusBarIconView extends AnimatedImageView {
private void setContentDescription(Notification notification) {
if (notification != null) {
CharSequence tickerText = notification.tickerText;
if (!TextUtils.isEmpty(tickerText)) {
setContentDescription(tickerText);
String d = contentDescForNotification(mContext, notification);
if (!TextUtils.isEmpty(d)) {
setContentDescription(d);
}
}
}
@@ -322,4 +322,12 @@ public class StatusBarIconView extends AnimatedImageView {
public String getSlot() {
return mSlot;
}
public static String contentDescForNotification(Context c, Notification n) {
Notification.Builder builder = Notification.Builder.recoverBuilder(c, n);
String appName = builder.loadHeaderAppName();
CharSequence ticker = n.tickerText;
return c.getString(R.string.accessibility_desc_notification_icon, appName, ticker);
}
}