【Android】状态栏通知Notification、NotificationManager详解

在Android系统中,发一个状态栏通知还是很方便的。下面我们就来看一下,怎么发送状态栏通知,状态栏通知又有哪些参数可以设置?

首先,发送一个状态栏通知必须用到两个类: NotificationManager 、Notification。

NotificationManager: 是状态栏通知的管理类,负责发通知、清楚通知等。

NotificationManager 是一个系统Service,必须通过getSystemService()方法来获取。

  1. NotificationManagernm=(NotificationManager)getSystemService(NOTIFICATION_SERVICE);

Notification:是具体的状态栏通知对象,可以设置icon、文字、提示声音、振动等等参数。

下面是设置一个通知需要的基本参数:

  • An icon (通知的图标)
  • A title and expanded message (通知的标题和内容)
  • APendingIntent (点击通知执行页面跳转)

可选的设置:

  • 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. 基本设置:

  1. //新建状态栏通知
  2. baseNF=newNotification();
  3. //设置通知在状态栏显示的图标
  4. baseNF.icon=R.drawable.icon;
  5. //通知时在状态栏显示的内容
  6. baseNF.tickerText="YouclickedBaseNF!";
  7. //通知的默认参数DEFAULT_SOUND,DEFAULT_VIBRATE,DEFAULT_LIGHTS.
  8. //如果要全部采用默认值,用DEFAULT_ALL.
  9. //此处采用默认声音
  10. baseNF.defaults=Notification.DEFAULT_SOUND;
  11. //第二个参数:下拉状态栏时显示的消息标题expandedmessagetitle
  12. //第三个参数:下拉状态栏时显示的消息内容expandedmessagetext
  13. //第四个参数:点击该通知时执行页面跳转
  14. baseNF.setLatestEventInfo(Lesson_10.this,"Title01","Content01",pd);
  15. //发出状态栏通知
  16. //ThefirstparameteristheuniqueIDfortheNotification
  17. //andthesecondistheNotificationobject.
  18. nm.notify(Notification_ID_BASE,baseNF);

配一张图作说明:

【Android】状态栏通知Notification、NotificationManager详解

2. 添加声音

如果要采用默认声音,只要使用default就可以了。

  1. baseNF.defaults=Notification.DEFAULT_SOUND;

如果要使用自定义声音,那么就要用到sound了。如下:

  1. notification.sound=Uri.parse("file:///sdcard/notification/ringer.mp3");

上面这种方法,使用的是自己的铃声,如果想用系统自带的铃声,可以这样:

  1. notification.sound=Uri.withAppendedPath(Audio.Media.INTERNAL_CONTENT_URI,"6");

需要注意一点,如果default、sound同时出现,那么sound无效,会使用默认铃声。

默认情况下,通知的声音播放一遍就会结束。 如果你想让声音循环播放,需要为flags参数加上FLAG_INSISTENT。 这样声音会到用户响应才结束,比如下拉状态栏。

  1. notification.flags|=notification.FLAG_INSISTENT;

3. 添加振动

如果是使用默认的振动方式,那么同样也是使用default。

  1. notification.defaults|=Notification.DEFAULT_VIBRATE;

当然也可以自己定义振动形式,这边需要用到Long型数组。

  1. long[]vibrate={0,100,200,300};
  2. notification.vibrate=vibrate;

这边的Long型数组中,第一个参数是开始振动前等待的时间,第二个参数是第一次振动的时间,第三个参数是第二次振动的时间,以此类推,随便定义多长的数组。但是采用这种方法,没有办法做到重复振动。

同样,如果default、vibrate同时出现时,会采用默认形式。

另外还需要注意一点:使用振动器时需要权限,如下:

  1. <uses-permissionandroid:name="android.permission.VIBRATE"></uses-permission>

4. 闪光

使用默认的灯光,如下:

  1. notification.defaults|=Notification.DEFAULT_LIGHTS;

自定义

  1. notification.ledARGB=0xff00ff00;
  2. notification.ledOnMS=300;
  3. notification.ledOffMS=1000;
  4. notification.flags|=Notification.FLAG_SHOW_LIGHTS;

其中ledARGB 表示灯光颜色、ledOnMS 亮持续时间、ledOffMS 暗的时间。

注意:这边的颜色跟设备有关,不是所有的颜色都可以,要看具体设备。

5.其他有用的设置:

flags

Notification.FLAG_INSISTENT; //让声音、振动无限循环,直到用户响应

Notification.FLAG_AUTO_CANCEL; //通知被点击后,自动消失

Notification.FLAG_NO_CLEAR; //点击'Clear'时,不清楚该通知(QQ的通知无法清除,就是用的这个)


下面附上我做的例子,供大家参考。 里面包括创建通知、更新通知、清除通知、设置自定义铃声、自定义振动、自定义通知视图等。

【Android】状态栏通知Notification、NotificationManager详解【Android】状态栏通知Notification、NotificationManager详解

附上代码:

主类:

  1. packagecom.yfz;
  2. importandroid.app.Activity;
  3. importandroid.app.Notification;
  4. importandroid.app.NotificationManager;
  5. importandroid.app.PendingIntent;
  6. importandroid.content.Intent;
  7. importandroid.net.Uri;
  8. importandroid.os.Bundle;
  9. importandroid.provider.MediaStore.Audio;
  10. importandroid.util.Log;
  11. importandroid.view.View;
  12. importandroid.view.View.OnClickListener;
  13. importandroid.widget.Button;
  14. importandroid.widget.RemoteViews;
  15. importandroid.widget.SeekBar;
  16. importandroid.widget.TextView;
  17. /**
  18. *Notification
  19. *@authorAdministrator
  20. *
  21. */
  22. publicclassLesson_10extendsActivity{
  23. //BaseNotification
  24. privateButtonbt01;
  25. //UpdateBaseNotification
  26. privateButtonbt02;
  27. //ClearBaseNotification
  28. privateButtonbt03;
  29. //MediaNotification
  30. privateButtonbt04;
  31. //ClearMediaNotification
  32. privateButtonbt05;
  33. //ClearALL
  34. privateButtonbt06;
  35. //CustomNotification
  36. privateButtonbt07;
  37. //通知管理器
  38. privateNotificationManagernm;
  39. //通知显示内容
  40. privatePendingIntentpd;
  41. @Override
  42. publicvoidonCreate(BundlesavedInstanceState){
  43. super.onCreate(savedInstanceState);
  44. /*加载页面*/
  45. setContentView(R.layout.lesson10);
  46. init();
  47. }
  48. privatevoidinit(){
  49. bt01=(Button)findViewById(R.id.le10bt01);
  50. bt02=(Button)findViewById(R.id.le10bt02);
  51. bt03=(Button)findViewById(R.id.le10bt03);
  52. bt04=(Button)findViewById(R.id.le10bt04);
  53. bt05=(Button)findViewById(R.id.le10bt05);
  54. bt06=(Button)findViewById(R.id.le10bt06);
  55. bt07=(Button)findViewById(R.id.le10bt07);
  56. bt01.setOnClickListener(onclick);
  57. bt02.setOnClickListener(onclick);
  58. bt03.setOnClickListener(onclick);
  59. bt04.setOnClickListener(onclick);
  60. bt05.setOnClickListener(onclick);
  61. bt06.setOnClickListener(onclick);
  62. bt07.setOnClickListener(onclick);
  63. nm=(NotificationManager)getSystemService(NOTIFICATION_SERVICE);
  64. Intentintent=newIntent(this,Lesson_10.class);
  65. pd=PendingIntent.getActivity(Lesson_10.this,0,intent,0);
  66. }
  67. OnClickListeneronclick=newOnClickListener(){
  68. //BASENotificationID
  69. privateintNotification_ID_BASE=110;
  70. privateNotificationbaseNF;
  71. //NotificationID
  72. privateintNotification_ID_MEDIA=119;
  73. privateNotificationmediaNF;
  74. @Override
  75. publicvoidonClick(Viewv){
  76. switch(v.getId()){
  77. caseR.id.le10bt01:
  78. //新建状态栏通知
  79. baseNF=newNotification();
  80. //设置通知在状态栏显示的图标
  81. baseNF.icon=R.drawable.icon;
  82. //通知时在状态栏显示的内容
  83. baseNF.tickerText="YouclickedBaseNF!";
  84. //通知的默认参数DEFAULT_SOUND,DEFAULT_VIBRATE,DEFAULT_LIGHTS.
  85. //如果要全部采用默认值,用DEFAULT_ALL.
  86. //此处采用默认声音
  87. baseNF.defaults|=Notification.DEFAULT_SOUND;
  88. baseNF.defaults|=Notification.DEFAULT_VIBRATE;
  89. baseNF.defaults|=Notification.DEFAULT_LIGHTS;
  90. //让声音、振动无限循环,直到用户响应
  91. baseNF.flags|=Notification.FLAG_INSISTENT;
  92. //通知被点击后,自动消失
  93. baseNF.flags|=Notification.FLAG_AUTO_CANCEL;
  94. //点击'Clear'时,不清楚该通知(QQ的通知无法清除,就是用的这个)
  95. baseNF.flags|=Notification.FLAG_NO_CLEAR;
  96. //第二个参数:下拉状态栏时显示的消息标题expandedmessagetitle
  97. //第三个参数:下拉状态栏时显示的消息内容expandedmessagetext
  98. //第四个参数:点击该通知时执行页面跳转
  99. baseNF.setLatestEventInfo(Lesson_10.this,"Title01","Content01",pd);
  100. //发出状态栏通知
  101. //ThefirstparameteristheuniqueIDfortheNotification
  102. //andthesecondistheNotificationobject.
  103. nm.notify(Notification_ID_BASE,baseNF);
  104. break;
  105. caseR.id.le10bt02:
  106. //更新通知
  107. //比如状态栏提示有一条新短信,还没来得及查看,又来一条新短信的提示。
  108. //此时采用更新原来通知的方式比较。
  109. //(再重新发一个通知也可以,但是这样会造成通知的混乱,而且显示多个通知给用户,对用户也不友好)
  110. baseNF.setLatestEventInfo(Lesson_10.this,"Title02","Content02",pd);
  111. nm.notify(Notification_ID_BASE,baseNF);
  112. break;
  113. caseR.id.le10bt03:
  114. //清除baseNF
  115. nm.cancel(Notification_ID_BASE);
  116. break;
  117. caseR.id.le10bt04:
  118. mediaNF=newNotification();
  119. mediaNF.icon=R.drawable.icon;
  120. mediaNF.tickerText="YouclickedMediaNF!";
  121. //自定义声音
  122. mediaNF.sound=Uri.withAppendedPath(Audio.Media.INTERNAL_CONTENT_URI,"6");
  123. //通知时发出的振动
  124. //第一个参数:振动前等待的时间
  125. //第二个参数:第一次振动的时长、以此类推
  126. long[]vir={0,100,200,300};
  127. mediaNF.vibrate=vir;
  128. mediaNF.setLatestEventInfo(Lesson_10.this,"Title03","Content03",pd);
  129. nm.notify(Notification_ID_MEDIA,mediaNF);
  130. break;
  131. caseR.id.le10bt05:
  132. //清除mediaNF
  133. nm.cancel(Notification_ID_MEDIA);
  134. break;
  135. caseR.id.le10bt06:
  136. nm.cancelAll();
  137. break;
  138. caseR.id.le10bt07:
  139. //自定义下拉视图,比如下载软件时,显示的进度条。
  140. Notificationnotification=newNotification();
  141. notification.icon=R.drawable.icon;
  142. notification.tickerText="Custom!";
  143. RemoteViewscontentView=newRemoteViews(getPackageName(),R.layout.custom);
  144. contentView.setImageViewResource(R.id.image,R.drawable.icon);
  145. contentView.setTextViewText(R.id.text,"Hello,thismessageisinacustomexpandedview");
  146. notification.contentView=contentView;
  147. //使用自定义下拉视图时,不需要再调用setLatestEventInfo()方法
  148. //但是必须定义contentIntent
  149. notification.contentIntent=pd;
  150. nm.notify(3,notification);
  151. break;
  152. }
  153. }
  154. };
  155. }

主页面:

  1. <?xmlversion="1.0"encoding="utf-8"?>
  2. <LinearLayout
  3. xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. android:orientation="vertical">
  7. <Button
  8. android:id="@+id/le10bt01"
  9. android:layout_width="fill_parent"
  10. android:layout_height="wrap_content"
  11. android:text="BaseNotification"
  12. />
  13. <Button
  14. android:id="@+id/le10bt02"
  15. android:layout_width="fill_parent"
  16. android:layout_height="wrap_content"
  17. android:text="UpdateBaseNotification"
  18. />
  19. <Button
  20. android:id="@+id/le10bt03"
  21. android:layout_width="fill_parent"
  22. android:layout_height="wrap_content"
  23. android:text="ClearBaseNotification"
  24. />
  25. <Button
  26. android:id="@+id/le10bt04"
  27. android:layout_width="fill_parent"
  28. android:layout_height="wrap_content"
  29. android:text="MediaNotification"
  30. />
  31. <Button
  32. android:id="@+id/le10bt05"
  33. android:layout_width="fill_parent"
  34. android:layout_height="wrap_content"
  35. android:text="ClearMediaNotification"
  36. />
  37. <Button
  38. android:id="@+id/le10bt06"
  39. android:layout_width="fill_parent"
  40. android:layout_height="wrap_content"
  41. android:text="ClearALL"
  42. />
  43. <Button
  44. android:id="@+id/le10bt07"
  45. android:layout_width="fill_parent"
  46. android:layout_height="wrap_content"
  47. android:text="CustomNotification"
  48. />
  49. </LinearLayout>

自定义视图页面:

  1. <?xmlversion="1.0"encoding="utf-8"?>
  2. <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="horizontal"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. android:padding="3dp"
  7. >
  8. <ImageViewandroid:id="@+id/image"
  9. android:layout_width="wrap_content"
  10. android:layout_height="fill_parent"
  11. android:layout_marginRight="10dp"
  12. />
  13. <TextViewandroid:id="@+id/text"
  14. android:layout_width="wrap_content"
  15. android:layout_height="fill_parent"
  16. android:textColor="#000"
  17. />
  18. </LinearLayout>