【Android】状态栏通知Notification、NotificationManager详解
在Android系统中,发一个状态栏通知还是很方便的。下面我们就来看一下,怎么发送状态栏通知,状态栏通知又有哪些参数可以设置?
首先,发送一个状态栏通知必须用到两个类: NotificationManager 、Notification。
NotificationManager: 是状态栏通知的管理类,负责发通知、清楚通知等。
NotificationManager 是一个系统Service,必须通过getSystemService()方法来获取。
- NotificationManagernm=(NotificationManager)getSystemService(NOTIFICATION_SERVICE);
Notification:是具体的状态栏通知对象,可以设置icon、文字、提示声音、振动等等参数。
下面是设置一个通知需要的基本参数:
- An icon (通知的图标)
- A title and expanded message (通知的标题和内容)
- A
PendingIntent (点击通知执行页面跳转)
可选的设置:
- A ticker-text message (状态栏顶部提示消息)
- An alert sound (提示音)
- A vibrate setting (振动)
- A flashing LED setting (灯光)
- 等等
一、创建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的通知无法清除,就是用的这个)
下面附上我做的例子,供大家参考。 里面包括创建通知、更新通知、清除通知、设置自定义铃声、自定义振动、自定义通知视图等。
附上代码:
主类:
- packagecom.yfz;
- importandroid.app.Activity;
- importandroid.app.Notification;
- importandroid.app.NotificationManager;
- importandroid.app.PendingIntent;
- importandroid.content.Intent;
- importandroid.net.Uri;
- importandroid.os.Bundle;
- importandroid.provider.MediaStore.Audio;
- importandroid.util.Log;
- importandroid.view.View;
- importandroid.view.View.OnClickListener;
- importandroid.widget.Button;
- importandroid.widget.RemoteViews;
- importandroid.widget.SeekBar;
- importandroid.widget.TextView;
- /**
- *Notification
- *@authorAdministrator
- *
- */
- publicclassLesson_10extendsActivity{
- //BaseNotification
- privateButtonbt01;
- //UpdateBaseNotification
- privateButtonbt02;
- //ClearBaseNotification
- privateButtonbt03;
- //MediaNotification
- privateButtonbt04;
- //ClearMediaNotification
- privateButtonbt05;
- //ClearALL
- privateButtonbt06;
- //CustomNotification
- privateButtonbt07;
- //通知管理器
- privateNotificationManagernm;
- //通知显示内容
- privatePendingIntentpd;
- @Override
- publicvoidonCreate(BundlesavedInstanceState){
- super.onCreate(savedInstanceState);
- /*加载页面*/
- setContentView(R.layout.lesson10);
- init();
- }
- privatevoidinit(){
- bt01=(Button)findViewById(R.id.le10bt01);
- bt02=(Button)findViewById(R.id.le10bt02);
- bt03=(Button)findViewById(R.id.le10bt03);
- bt04=(Button)findViewById(R.id.le10bt04);
- bt05=(Button)findViewById(R.id.le10bt05);
- bt06=(Button)findViewById(R.id.le10bt06);
- bt07=(Button)findViewById(R.id.le10bt07);
- bt01.setOnClickListener(onclick);
- bt02.setOnClickListener(onclick);
- bt03.setOnClickListener(onclick);
- bt04.setOnClickListener(onclick);
- bt05.setOnClickListener(onclick);
- bt06.setOnClickListener(onclick);
- bt07.setOnClickListener(onclick);
- nm=(NotificationManager)getSystemService(NOTIFICATION_SERVICE);
- Intentintent=newIntent(this,Lesson_10.class);
- pd=PendingIntent.getActivity(Lesson_10.this,0,intent,0);
- }
- OnClickListeneronclick=newOnClickListener(){
- //BASENotificationID
- privateintNotification_ID_BASE=110;
- privateNotificationbaseNF;
- //NotificationID
- privateintNotification_ID_MEDIA=119;
- privateNotificationmediaNF;
- @Override
- publicvoidonClick(Viewv){
- switch(v.getId()){
- caseR.id.le10bt01:
- //新建状态栏通知
- baseNF=newNotification();
- //设置通知在状态栏显示的图标
- baseNF.icon=R.drawable.icon;
- //通知时在状态栏显示的内容
- baseNF.tickerText="YouclickedBaseNF!";
- //通知的默认参数DEFAULT_SOUND,DEFAULT_VIBRATE,DEFAULT_LIGHTS.
- //如果要全部采用默认值,用DEFAULT_ALL.
- //此处采用默认声音
- baseNF.defaults|=Notification.DEFAULT_SOUND;
- baseNF.defaults|=Notification.DEFAULT_VIBRATE;
- baseNF.defaults|=Notification.DEFAULT_LIGHTS;
- //让声音、振动无限循环,直到用户响应
- baseNF.flags|=Notification.FLAG_INSISTENT;
- //通知被点击后,自动消失
- baseNF.flags|=Notification.FLAG_AUTO_CANCEL;
- //点击'Clear'时,不清楚该通知(QQ的通知无法清除,就是用的这个)
- baseNF.flags|=Notification.FLAG_NO_CLEAR;
- //第二个参数:下拉状态栏时显示的消息标题expandedmessagetitle
- //第三个参数:下拉状态栏时显示的消息内容expandedmessagetext
- //第四个参数:点击该通知时执行页面跳转
- baseNF.setLatestEventInfo(Lesson_10.this,"Title01","Content01",pd);
- //发出状态栏通知
- //ThefirstparameteristheuniqueIDfortheNotification
- //andthesecondistheNotificationobject.
- nm.notify(Notification_ID_BASE,baseNF);
- break;
- caseR.id.le10bt02:
- //更新通知
- //比如状态栏提示有一条新短信,还没来得及查看,又来一条新短信的提示。
- //此时采用更新原来通知的方式比较。
- //(再重新发一个通知也可以,但是这样会造成通知的混乱,而且显示多个通知给用户,对用户也不友好)
- baseNF.setLatestEventInfo(Lesson_10.this,"Title02","Content02",pd);
- nm.notify(Notification_ID_BASE,baseNF);
- break;
- caseR.id.le10bt03:
- //清除baseNF
- nm.cancel(Notification_ID_BASE);
- break;
- caseR.id.le10bt04:
- mediaNF=newNotification();
- mediaNF.icon=R.drawable.icon;
- mediaNF.tickerText="YouclickedMediaNF!";
- //自定义声音
- mediaNF.sound=Uri.withAppendedPath(Audio.Media.INTERNAL_CONTENT_URI,"6");
- //通知时发出的振动
- //第一个参数:振动前等待的时间
- //第二个参数:第一次振动的时长、以此类推
- long[]vir={0,100,200,300};
- mediaNF.vibrate=vir;
- mediaNF.setLatestEventInfo(Lesson_10.this,"Title03","Content03",pd);
- nm.notify(Notification_ID_MEDIA,mediaNF);
- break;
- caseR.id.le10bt05:
- //清除mediaNF
- nm.cancel(Notification_ID_MEDIA);
- break;
- caseR.id.le10bt06:
- nm.cancelAll();
- break;
- caseR.id.le10bt07:
- //自定义下拉视图,比如下载软件时,显示的进度条。
- 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);
- break;
- }
- }
- };
- }
主页面:
- <?xmlversion="1.0"encoding="utf-8"?>
- <LinearLayout
- xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:orientation="vertical">
- <Button
- android:id="@+id/le10bt01"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:text="BaseNotification"
- />
- <Button
- android:id="@+id/le10bt02"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:text="UpdateBaseNotification"
- />
- <Button
- android:id="@+id/le10bt03"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:text="ClearBaseNotification"
- />
- <Button
- android:id="@+id/le10bt04"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:text="MediaNotification"
- />
- <Button
- android:id="@+id/le10bt05"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:text="ClearMediaNotification"
- />
- <Button
- android:id="@+id/le10bt06"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:text="ClearALL"
- />
- <Button
- android:id="@+id/le10bt07"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:text="CustomNotification"
- />
- </LinearLayout>
自定义视图页面:
- <?xmlversion="1.0"encoding="utf-8"?>
- <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="horizontal"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:padding="3dp"
- >
- <ImageViewandroid:id="@+id/image"
- android:layout_width="wrap_content"
- android:layout_height="fill_parent"
- android:layout_marginRight="10dp"
- />
- <TextViewandroid:id="@+id/text"
- android:layout_width="wrap_content"
- android:layout_height="fill_parent"
- android:textColor="#000"
- />
- </LinearLayout>