什么是通知(Notification):
当某个app希望向用户发出一些提示性信息,而又不在前台运行时,可以借助通知实现。
发出一条通知后,手机最上方状态栏会显示一个通知的图标,下拉状态栏可以看到通知的详细内容。
通知的基本用法:
通知可以在活动Activity 广播接收器Receiver服务Service 中创建。
但主要在Receiver和Service中创建,因为一般只有当程序进入到后台时,我们才需要使用通知。
使用通知的详细步骤:
首先需要NotificationManager对通知进行管理:调用Context类的getSystemService()方法获取NotificationManager对象。
NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
得到NotificationManager后,我们需要创建Notification对象。这个对象存储通知所需的各种信息。
Notification的有参构造函数接收三个参数:
1.通知的图标;
2.ticker内容(它会在系统状态栏一闪而过)
3.指定通知被创建的时间,毫秒为单位。
Notification notification = new Notification(R.drawable.a, "this is ticker text",System.currentTimeMillis());
创建好Notification对象后,我们需要对它的布局进行设定:
Notification的setLatestEventInfo()方法接收4个参数,分别为:
1.Context
2.Title
3.Message
4.暂时传入null,更多内容见本篇下面PendingIntent。
notification.setLatestEventInfo(this, "title", "text", null);
最后一步,调用NotificationManager的notify()方法就可以让通知显示出来啦!
notify()方法接收两个参数:
1.id,int类型参数
2.Notification对象。
notificationManager.notify(1, notification);
============================快乐的分割线========================================
在这里虽然我们的通知创建好了,但是却发现点击是没有反应的!
如果你用过Android手机,你一定觉得这是无法忍受的事情。
接下来我们为通知实现点击效果吧。
新的概念:PendingIntent
PendingIntent与Intent有些类似。它们都可以去指明某个“意图”,都可以用来启动活动,启动服务,发送广播等。不同的是,Intent倾向于立即执行某个动作,而PendingIntent倾向于在某个合适的时机去执行某个动作。所以也可以把PendingIntent理解为延时执行的Intent。
PendingIntent的用法:
它主要提供了几个静态方法来获得PendingIntent的实例,根据需求选择getActivity(),getBroadcast()还是getService().
这几个方法接收的参数是相同的:
1.Context
2.第二个参数通常用不到,传入0即可
3.Intent对象,通过这个对象构建出PendingIntent的意图。
4.确定PendingIntent的行为,有以下几种值:
FLAG_ONE_SHOT;FLAG_NO_CREATE;FLAG_CANCEL_CURRENT;FLAG_UPDATE_CURRENT
完整用法:
NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
Notification notification = new Notification(R.drawable.abc_btn_default_mtrl_shape, "this is ticker text",
System.currentTimeMillis());
Intent intent = new Intent(MainActivity.this, NotificationActivity.class);
PendingIntent pi = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_CANCEL_CURRENT);
notification.setLatestEventInfo(this, "title", "text", pi);
notificationManager.notify(1, notification);