Android学习系列之-通知Notification

今天打算介绍下通知的基本使用方法。首先,看下官网的介绍。

通知是可以在应用的常规 UI 外部向用户显示的消息。当您告知系统发出通知时,它将先以图标的形式显示在通知区域中。用户可以打开抽屉式通知栏查看通知的详细信息。 通知区域和抽屉式通知栏均是由系统控制的区域,用户可以随时查看。

具体的展示如下:
图1 通知区域中的通知。
图2 抽屉式通知栏中的通知
相信看完介绍,大家应该也都明白通知的一些使用场景了。现在大部分的应用都有推送功能,而推送都是用通知来展示的。比如简书每天就不定时的给你发推送。下面就介绍一下通知的具体使用方法。

基本知识

要创建通知,我们就需要Notification这个类,我们可以通过 NotificationCompat.Builder 对象中为通知指定 UI 信息和操作,然后通过调用 NotificationCompat.Builder.build(),它将返回包含您的具体规范的 Notification 对象。然后通过 NotificationManager.notify()
 将 Notification 对象传递给系统,由系统来帮你完成后续的处理。
Notification对象必须包含以下三个元素:

  • 小图标,由 setSmallIcon() 方法设置
  • 标题,由 setContentTitle 方法设置
  • 详细文本,由 setContentText()设置

也就是说这三个元素是必须的,不然就算创建了Notification对象也是发不出去的。另外就是需要解释一下这个小图标,小图标是指图一通知区域的小图标,也是图二中通知大图右下角的小图片,他是一个特殊的图。5.0后Android官方要求,所有应用程序的通知栏图标,应该只使用alpha图层来进行绘制,而不应该包括RGB图层。即不要为通知的图标添加任何额外的透明度,渐变色,不要用颜色将通知图标与其他应用,比如系统应用,应用的通知图标(即小图标)只能是在透明的背景上有白色的图案。
另外具体的设计可以参考materia design 关于Notification的设计规范,地址https://material.io/guidelines/patterns/notifications.html
下面贴两张图来让大家更明了各个参数对应的UI显示,
small_icon.png
通知各元素对应的显示

上图的NotificationIcon 其实是smallIcon,Title即ContentTitle,Message即ContentText,另外还有时间戳等。所有的通知的其他设置都是可选的。

通知操作

我们设置好了通知之后,需要再向通知添加一个操作,以用来相应用户的点击操作。当然你也可以不加这个操作,就让它挂在通知栏,用户点了就是没反应,但是这样用户体验多不好。用户点击通知后可以让用户从通知直接跳转到相应的activity,以执行下一步操作。在 Notification内部,操作本身由 PendingIntent 定义,后者包含在应用中启动 Activity的 Intent。

创建通知

我们可以通过以下步骤去创建一个通知

  1. 先创建NotificationCompat.Builder,并且可以通过这个builder去设置通知需要的内容,来生成Notification。

    1
    2
    3
    4
    5
    6
    7
    8
    NotificationCompat.Builder builder = new NotificationCompat.Builder(context);
    Notification notification = builder
    .setContentTitle("这是通知标题")
    .setContentText("这是通知内容")
    .setSmallIcon(R.mipmap.ic_launcher)
    .setLargeIcon(BitmapFactory.decodeResource(
    getResources(), R.mipmap.ic_launcher))
    .build();
  2. 设置优先级
    通知还有优先级,我们可以通过setPriority() 传入通知的优先级,目前通知的优先级有五个等级,范围从 PRIORITY_MIN (-2) 到 PRIORITY_MAX (2);如果未设置,则优先级默认为 PRIORITY_DEFAULT (0)。优先级越高,在通知栏就排的越往上。

  3. 设置一个点击后的动作
    如之前所说的,我们可以通过pendingIntent来设置一个通知点击后的操作。比如跳转到一个activity。

    1
    2
    3
    4
    Intent resultIntent = new Intent(this, ResultActivity.class);
    PendingIntent resultPendingIntent = PendingIntent.getActivity(
    this, 0, resultIntent, PendingIntent.FLAG_UPDATE_CURRENT);
    mBuilder.setContentIntent(resultPendingIntent);

    通过这种方式就可以让用户点击通知后跳转到ResultActivity页面了。

  4. 用NotificationManager 发送通知

    1
    2
    3
    4
    NotificationManager mNotificationManager =
    (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
    // mId allows you to update the notification later on.
    mNotificationManager.notify(mId, mBuilder.build());
  5. 更新通知
    当我们需要更新通知中的内容的时候就可以依据上面设置的通知的id去更新的通知,只需要通知Id相同就可以更新,具体操作其实和创建差不多,官方的示例代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    mNotificationManager =
    (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
    // Sets an ID for the notification, so it can be updated
    int notifyID = 1;
    mNotifyBuilder = new NotificationCompat.Builder(this)
    .setContentTitle("New Message")
    .setContentText("You've received new messages.")
    .setSmallIcon(R.drawable.ic_notify_status)
    numMessages = 0;
    // Start of a loop that processes data and then notifies the user
    ...
    mNotifyBuilder.setContentText(currentText)
    .setNumber(++numMessages);
    // Because the ID remains unchanged, the existing notification is
    // updated.
    mNotificationManager.notify(
    notifyID,
    mNotifyBuilder.build());
  6. 删除或取消通知
    当我们需要手动取消通知的时候,可以调用NotificationManager的 cancel(),具体的删除有以下几种方式:

  • 用户单独或通过使用“全部清除”清除了该通知(如果通知可以清除)。
  • 用户点击通知,且您在创建通知时调用了 setAutoCancel()
  • 针对特定的通知 ID 调用了 cancel() 此方法还会删除当前通知。
  • 调用了cancelAll()方法,该方法将删除之前发出的所有通知。

好了,到这里已经可以创建基本的Notification了,之后再写一些通知的其他使用方式。