| 雷峰网
1
本文作者: 稀土 | 2016-07-07 17:49 |
雷锋网按:本文由掘金翻译计划译者DeadLion译自Ian Lake《Notifications in Android N》,校对者:danke77, xcc3641。本文首发稀土掘金,未经允许,禁止转载。
Android通知往往是应用和用户之间至关重要的交互形式。为了提供更好的用户体验,Android N在通知上做出了诸多改进:收到消息后的视觉刷新,改进对自定义视图的支持,扩展了更加实用的直接回复消息的形式,新的 MessagingStyle
,捆绑的通知。
首先,最明显的变化是通知的默认外观已经显著改变。除了应用程序的图标和名称会固定在通知内,很多分散在通知周围的字段也被折叠进新的标题行内。这一改变是为了确保尽可能腾出更多空间给标题、文本和大图标,这样一来通知就比现在的稍大些,更加易读。
给出单标题行,这就比以往的信息更加重要且更有用。当指定Android N时,默认情况下,时间会被隐藏——对时间敏感的通知(比如消息类应用),可以setShowWhen(true)
设置重新启用显示时间。此外,现在subtext会取代内容消息和数量的作用:数量是绝不会在Android N设备上出现的,除非指定之前的Android版本,而且不包含任何subtext,内容消息将会显示。在所有情况下,都要确保subtext是相关且有意义的。例如,如果用户只有一个账号,就不要再添加邮箱账户作为subtext了。
通知收到后的操作也重新设计了,现在视觉上是在通知下方单独的一栏中。
你会注意到,图标都没有出现在新的通知中,取而代之的是,将通知内有限的空间提供给了标签本身。然而,在旧版本的 Android 和设备上,通知操作图标仍然需要且被继续使用,如Android Wear。
如果你使用NotificationCompat.Builder创建了自己的通知,那么可以使用标准样式,无需修改任何代码就能变成默认的新样子。
如果要从自定义 RemoteViews
创建自己的通知,以适应任何新的样式一直以来都很具有挑战性。随着新的 header,扩展行为,操作,和大图标位置都作为元素从通知的主要内容标题中分离出来,我们已经介绍一种新的 DecoratedCustomViewStyle
和 DecoratedMediaCustomViewStyle
提供所有这些元素使用, 这样就能使用新的 setCustomContentView()
方法,专注于内容部分。
这也确保未来外观改变了,也能轻易的随着平台更新,适配这些样式,还无需修改app端的代码。
虽然通知是可以用来启动一个Activity
,或以一个Service
、BroadcastReceiver
的方式在后台工作,直接回复允许你使用通知操作直接在内嵌输入框中回复。
直接回复使用相同的RemoteInput API,最初是为Android Wear某个Action用的,为了能直接接收用户的输入。
RemoteInput
本身包含信息,如将用于以后恢复输入的秘钥,在用户开始输入之前的提示信息。
// Where should direct replies be put in the intent bundle (can be any string) private static final String KEY_TEXT_REPLY = "key_text_reply"; // Create the RemoteInput specifying this key String replyLabel = getString(R.string.reply_label); RemoteInput remoteInput = new RemoteInput.Builder(KEY_TEXT_REPLY) .setLabel(replyLabel) .build();
一旦已经构造好RemoteInput
,可以通过恰当命名的addRemoteInput())方法附加到Action上。也可以考虑调用setAllowGeneratedReplies(true)
方法允许Android Wear 2.0生成智能回复,方便用户快速回应。
// Add to your action, enabling Direct Reply for it NotificationCompat.Action action = new NotificationCompat.Action.Builder(R.drawable.reply, replyLabel, pendingIntent) .addRemoteInput(remoteInput) .setAllowGeneratedReplies(true) .build();
请记住,在Marshmallow中,被传入Action
的pendingIntent
应该是一个Activity
。更低版本的设备不支持直接回复(你可能会想解锁屏幕,启动一个Activity
,然后聚焦到用户回复的输入框中),Android N设备上Service
(如果你想要在一个单独的线程中运行) 或BroadcastReceiver
(运行在UI线程中) 即便处于锁频状态,后台也能处理文本输入。(在系统设置中有一个独立的用户选项,可以启用/禁用锁定设备的直接回复功能。)
在Service
/BroadcastReceiver
中提取输入的文本,可能需要RemoteInput.getResultsFromIntent())的帮助。
private CharSequence getMessageText(Intent intent) { Bundle remoteInput = RemoteInput.getResultsFromIntent(intent); if (remoteInput != null) { return remoteInput.getCharSequence(KEY_TEXT_REPLY); } return null; }
处理文本后,必须更新通知。这将触发隐藏直接回复 UI,这可以作为一种技巧来确认用户是否收到回复并正确处理。
对于大多数模板,这将涉及使用新的setRemoteInputHistory()
方法,将答复追加到通知底部。更多回复应该追到历史记录下,直到主要内容更新(比如别人的回复)。
不过,如果你是在做一个消息应用,期待着“你来我往”的对话,那就应该用MessagingStyle
,将额外消息追加上去。
我们已经优化过正在对话状态中消息的显示,用新的MessagingStyle
直接回复。
对于通过多addMessage()
方法增加多条消息,这种风格提供内置的格式化。每个消息支持通过文本本身、一个时间戳,以及消息的发送人来增加(使它易于支持组对话)。
builder.setStyle(new NotificationCompat.MessagingStyle("Me") .setConversationTitle("Team lunch") .addMessage("Hi", timestampMillis1, null) // Pass in null for user. .addMessage("What's up?", timestampMillis2, "Coworker") .addMessage("Not much", timestampMillis3, null) .addMessage("How about lunch?", timestampMillis4, "Coworker"));
你可能会注意到,这种风格能很好的支持特殊用户消息的展示,填写它们的名字(上例中的“Me”),设置一个可选的对话标题。
虽然可以手动通过 “BigTextStyle” 来完成,使用这种风格的 Android Wear 2.0 用户能立即得到内置响应,不会被“踢出”扩展通知视图,无需创建完整的穿戴(Android Wear)应用就能达到无缝体验。
一旦你想建立了一个“巨牛逼”的通知,通过使用新的视觉设计,直接回复,MessagingStyle
还有所有之前最佳实践,但考虑通知的整体体验也很重要,尤其是发送多条通知的情况(每个正在进行的谈话或每个新的电子邮件线程)。
捆绑通知提供两全其美的办法:一个单独的概要通知,当用户在看其他通知或者想要同时操作所有通知时在个别通知上扩展了组操作能力(包括使用操作和直接回复)。
如果你为Android Wear创建了堆通知,这里使用的API是完全一样的。只需将setGroup())添加到每个单独通知中,将那些通知“绑定”到一起。不仅限于绑定成一组,所有捆绑通知是十分灵活的。对于邮件应用,可能考虑每个账户的邮件“捆”成一组。
创建概要通知也是很重要的。这个概要通知,通过setGroupSummary(true)) 展示通知,这也是唯一支持 Marshmallow和更低版本的设备的通知,会归纳所有个人通知(你猜对了)。这是使用InboxStyle的最佳时机,虽然没有要求用它。在Android N或更高版本设备上,从概要通知上提取的某些信息(如subtext、content intent和delete intent),来为捆绑通知生成collapsed通知,所以你应该继续在所有API级别上生成概要通知。
为了提升所有Android N设备的用户体验,发送4个或者更多通知时没有以组的方式,这些通知将自动合并成一组
通知在Android上是一直不断改进的功能。从Gingerbread时代的单击目标,到可扩展通知,操作,MediaStyle以及现在的直接回复,绑定通知。通知在Android用户体验上扮演着不可或缺的一部分。
随着许多新工具可使用(NotificationCompat能帮助保持向后兼容),我已经迫不及待的想看看如何用这些工具创建更好的应用。
雷峰网原创文章,未经授权禁止转载。详情见转载须知。