Notification与NotificationManager详细介绍
程序员文章站
2023-12-09 15:29:33
在android系统中,发一个状态栏通知还是很方便的。下面我们就来看一下,怎么发送状态栏通知,状态栏通知又有哪些参数可以设置? 首先,发送一个状态栏通知必须用到两个类:no...
在android系统中,发一个状态栏通知还是很方便的。下面我们就来看一下,怎么发送状态栏通知,状态栏通知又有哪些参数可以设置?
首先,发送一个状态栏通知必须用到两个类:notificationmanager、notification。
notificationmanager:是状态栏通知的管理类,负责发通知、清楚通知等。
notificationmanager是一个系统service,必须通过getsystemservice()方法来获取。
notificationmanagernm=(notificationmanager)getsystemservice(notification_service);
notification:是具体的状态栏通知对象,可以设置icon、文字、提示声音、振动等等参数。
下面是设置一个通知需要的基本参数:
anicon(通知的图标)
atitleandexpandedmessage(通知的标题和内容)
apendingintent(点击通知执行页面跳转)
一、创建notification
通过notificationmanager的notify(int,notification)方法来启动notification。
第一个参数唯一的标识该notification,第二个参数就是notification对象。
二、更新notification
调用notification的setlatesteventinfo方法来更新内容,然后再调用notificationmanager的notify()方法即可。(具体可以看下面的实例)
三、删除notification
通过notificationmanager的cancel(int)方法,来清除某个通知。其中参数就是notification的唯一标识id。
当然也可以通过cancelall()来清除状态栏所有的通知。
四、notification设置(振动、铃声等)
1.基本设置:
//新建状态栏通知
basenf=newnotification();
//设置通知在状态栏显示的图标
basenf.icon=r.drawable.icon;
//通知时在状态栏显示的内容
basenf.tickertext="youclickedbasenf!";
//通知的默认参数default_sound,default_vibrate,default_lights.
//如果要全部采用默认值,用default_all.
//此处采用默认声音
basenf.defaults=notification.default_sound;
//第二个参数:下拉状态栏时显示的消息标题expandedmessagetitle
//第三个参数:下拉状态栏时显示的消息内容expandedmessagetext
//第四个参数:点击该通知时执行页面跳转
basenf.setlatesteventinfo(lesson_10.this,"title01","content01",pd);
//发出状态栏通知
//thefirstparameteristheuniqueidforthenotification
//andthesecondisthenotificationobject.
nm.notify(notification_id_base,basenf);
2.添加声音
如果要采用默认声音,只要使用default就可以了。
basenf.defaults=notification.default_sound;
如果要使用自定义声音,那么就要用到sound了。如下:
notification.sound=uri.parse("file:///sdcard/notification/ringer.mp3");
上面这种方法,使用的是自己的铃声,如果想用系统自带的铃声,可以这样:
notification.sound=uri.withappendedpath(audio.media.internal_content_uri,"6");
需要注意一点,如果default、sound同时出现,那么sound无效,会使用默认铃声。
默认情况下,通知的声音播放一遍就会结束。如果你想让声音循环播放,需要为flags参数加上flag_insistent。这样声音会到用户响应才结束,比如下拉状态栏。
notification.flags|=notification.flag_insistent;
3.添加振动
如果是使用默认的振动方式,那么同样也是使用default。
notification.defaults|=notification.default_vibrate;
当然也可以自己定义振动形式,这边需要用到long型数组。
long[]vibrate={0,100,200,300};
notification.vibrate=vibrate;
这边的long型数组中,第一个参数是开始振动前等待的时间,第二个参数是第一次振动的时间,第三个参数是第二次振动的时间,以此类推,随便定义多长的数组。但是采用这种方法,没有办法做到重复振动。
同样,如果default、vibrate同时出现时,会采用默认形式。
另外还需要注意一点:使用振动器时需要权限,如下:
<uses-permissionandroid:name="android.permission.vibrate"></uses-permission>
4.闪光
使用默认的灯光,如下:
notification.defaults|=notification.default_lights;
自定义:
notification.ledargb=0xff00ff00;
notification.ledonms=300;
notification.ledoffms=1000;
notification.flags|=notification.flag_show_lights;
其中ledargb表示灯光颜色、ledonms亮持续时间、ledoffms暗的时间。
注意:这边的颜色跟设备有关,不是所有的颜色都可以,要看具体设备。
5.其他有用的设置:
flags:
notification.flag_insistent;//让声音、振动无限循环,直到用户响应
notification.flag_auto_cancel;//通知被点击后,自动消失
notification.flag_no_clear;//点击'clear'时,不清楚该通知(qq的通知无法清除,就是用的这个
//自定义下拉视图,比如下载软件时,显示的进度条。
notificationnotification=newnotification();
notification.icon=r.drawable.icon;
notification.tickertext="custom!";
remoteviewscontentview=newremoteviews(getpackagename(),r.layout.custom);
contentview.setimageviewresource(r.id.image,r.drawable.icon);
contentview.settextviewtext(r.id.text,"hello,thismessageisinacustomexpandedview");
notification.contentview=contentview;
//使用自定义下拉视图时,不需要再调用setlatesteventinfo()方法
//但是必须定义contentintent
notification.contentintent=pd;
nm.notify(3,notification);
首先,发送一个状态栏通知必须用到两个类:notificationmanager、notification。
notificationmanager:是状态栏通知的管理类,负责发通知、清楚通知等。
notificationmanager是一个系统service,必须通过getsystemservice()方法来获取。
notificationmanagernm=(notificationmanager)getsystemservice(notification_service);
notification:是具体的状态栏通知对象,可以设置icon、文字、提示声音、振动等等参数。
下面是设置一个通知需要的基本参数:
anicon(通知的图标)
atitleandexpandedmessage(通知的标题和内容)
apendingintent(点击通知执行页面跳转)
一、创建notification
通过notificationmanager的notify(int,notification)方法来启动notification。
第一个参数唯一的标识该notification,第二个参数就是notification对象。
二、更新notification
调用notification的setlatesteventinfo方法来更新内容,然后再调用notificationmanager的notify()方法即可。(具体可以看下面的实例)
三、删除notification
通过notificationmanager的cancel(int)方法,来清除某个通知。其中参数就是notification的唯一标识id。
当然也可以通过cancelall()来清除状态栏所有的通知。
四、notification设置(振动、铃声等)
1.基本设置:
复制代码 代码如下:
//新建状态栏通知
basenf=newnotification();
//设置通知在状态栏显示的图标
basenf.icon=r.drawable.icon;
//通知时在状态栏显示的内容
basenf.tickertext="youclickedbasenf!";
//通知的默认参数default_sound,default_vibrate,default_lights.
//如果要全部采用默认值,用default_all.
//此处采用默认声音
basenf.defaults=notification.default_sound;
//第二个参数:下拉状态栏时显示的消息标题expandedmessagetitle
//第三个参数:下拉状态栏时显示的消息内容expandedmessagetext
//第四个参数:点击该通知时执行页面跳转
basenf.setlatesteventinfo(lesson_10.this,"title01","content01",pd);
//发出状态栏通知
//thefirstparameteristheuniqueidforthenotification
//andthesecondisthenotificationobject.
nm.notify(notification_id_base,basenf);
2.添加声音
如果要采用默认声音,只要使用default就可以了。
复制代码 代码如下:
basenf.defaults=notification.default_sound;
如果要使用自定义声音,那么就要用到sound了。如下:
复制代码 代码如下:
notification.sound=uri.parse("file:///sdcard/notification/ringer.mp3");
上面这种方法,使用的是自己的铃声,如果想用系统自带的铃声,可以这样:
复制代码 代码如下:
notification.sound=uri.withappendedpath(audio.media.internal_content_uri,"6");
需要注意一点,如果default、sound同时出现,那么sound无效,会使用默认铃声。
默认情况下,通知的声音播放一遍就会结束。如果你想让声音循环播放,需要为flags参数加上flag_insistent。这样声音会到用户响应才结束,比如下拉状态栏。
复制代码 代码如下:
notification.flags|=notification.flag_insistent;
3.添加振动
如果是使用默认的振动方式,那么同样也是使用default。
复制代码 代码如下:
notification.defaults|=notification.default_vibrate;
当然也可以自己定义振动形式,这边需要用到long型数组。
复制代码 代码如下:
long[]vibrate={0,100,200,300};
notification.vibrate=vibrate;
这边的long型数组中,第一个参数是开始振动前等待的时间,第二个参数是第一次振动的时间,第三个参数是第二次振动的时间,以此类推,随便定义多长的数组。但是采用这种方法,没有办法做到重复振动。
同样,如果default、vibrate同时出现时,会采用默认形式。
另外还需要注意一点:使用振动器时需要权限,如下:
复制代码 代码如下:
<uses-permissionandroid:name="android.permission.vibrate"></uses-permission>
4.闪光
使用默认的灯光,如下:
复制代码 代码如下:
notification.defaults|=notification.default_lights;
自定义:
复制代码 代码如下:
notification.ledargb=0xff00ff00;
notification.ledonms=300;
notification.ledoffms=1000;
notification.flags|=notification.flag_show_lights;
其中ledargb表示灯光颜色、ledonms亮持续时间、ledoffms暗的时间。
注意:这边的颜色跟设备有关,不是所有的颜色都可以,要看具体设备。
5.其他有用的设置:
复制代码 代码如下:
flags:
notification.flag_insistent;//让声音、振动无限循环,直到用户响应
notification.flag_auto_cancel;//通知被点击后,自动消失
notification.flag_no_clear;//点击'clear'时,不清楚该通知(qq的通知无法清除,就是用的这个
//自定义下拉视图,比如下载软件时,显示的进度条。
notificationnotification=newnotification();
notification.icon=r.drawable.icon;
notification.tickertext="custom!";
remoteviewscontentview=newremoteviews(getpackagename(),r.layout.custom);
contentview.setimageviewresource(r.id.image,r.drawable.icon);
contentview.settextviewtext(r.id.text,"hello,thismessageisinacustomexpandedview");
notification.contentview=contentview;
//使用自定义下拉视图时,不需要再调用setlatesteventinfo()方法
//但是必须定义contentintent
notification.contentintent=pd;
nm.notify(3,notification);