【Android】狀態列通知Notification、NotificationManager詳解
在Android系統中,發一個狀態列通知還是很方便的。下面我們就來看一下,怎麼傳送狀態列通知,狀態列通知又有哪些引數可以設定?
首先,傳送一個狀態列通知必須用到兩個類: NotificationManager 、 Notification。
NotificationManager : 是狀態列通知的管理類,負責發通知、清楚通知等。
NotificationManager 是一個系統Service,必須通過 getSystemService()方法來獲取。
- NotificationManager nm = (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. 基本設定:
[java] view plaincopyprint?- //新建狀態列通知
- baseNF = new Notification();
- //設定通知在狀態列顯示的圖示
- baseNF.icon = R.drawable.icon;
- //通知時在狀態列顯示的內容
- baseNF.tickerText = "You clicked BaseNF!";
- //通知的預設引數 DEFAULT_SOUND, DEFAULT_VIBRATE, DEFAULT_LIGHTS.
- //如果要全部採用預設值, 用 DEFAULT_ALL.
- //此處採用預設聲音
- baseNF.defaults = Notification.DEFAULT_SOUND;
- //第二個引數 :下拉狀態列時顯示的訊息標題 expanded message title
- //第三個引數:下拉狀態列時顯示的訊息內容 expanded message text
- //第四個引數:點選該通知時執行頁面跳轉
- baseNF.setLatestEventInfo(Lesson_10.this, "Title01", "Content01", pd);
- //發出狀態列通知
- //The first parameter is the unique ID for the Notification
- // and the second is the Notification object.
- nm.notify(Notification_ID_BASE, baseNF);
配一張圖作說明:
2. 新增聲音
如果要採用預設聲音,只要使用default就可以了。
[java] view plaincopyprint?- baseNF.defaults = Notification.DEFAULT_SOUND;
如果要使用自定義聲音,那麼就要用到sound了。如下:
[java] view plaincopyprint?- notification.sound = Uri.parse("file:///sdcard/notification/ringer.mp3");
上面這種方法,使用的是自己的鈴聲,如果想用系統自帶的鈴聲,可以這樣:
[java] view plaincopyprint?- notification.sound = Uri.withAppendedPath(Audio.Media.INTERNAL_CONTENT_URI, "6");
需要注意一點,如果default、sound同時出現,那麼sound無效,會使用預設鈴聲。
預設情況下,通知的聲音播放一遍就會結束。 如果你想讓聲音迴圈播放,需要為flags引數加上FLAG_INSISTENT。 這樣聲音會到使用者響應才結束,比如下拉狀態列。
[java] view plaincopyprint?- notification.flags |= notification.FLAG_INSISTENT;
3. 新增振動
如果是使用預設的振動方式,那麼同樣也是使用default。
[java] view plaincopyprint?- notification.defaults |= Notification.DEFAULT_VIBRATE;
當然也可以自己定義振動形式,這邊需要用到Long型陣列。
[java] view plaincopyprint?- long[] vibrate = {0,100,200,300};
- notification.vibrate = vibrate;
這邊的Long型陣列中,第一個引數是開始振動前等待的時間,第二個引數是第一次振動的時間,第三個引數是第二次振動的時間,以此類推,隨便定義多長的陣列。但是採用這種方法,沒有辦法做到重複振動。
同樣,如果default、vibrate同時出現時,會採用預設形式。
另外還需要注意一點:使用振動器時需要許可權,如下:
[xhtml] view plaincopyprint?- <uses-permissionandroid:name="android.permission.VIBRATE"></uses-permission>
4. 閃光
使用預設的燈光,如下:
[java] view plaincopyprint?- notification.defaults |= Notification.DEFAULT_LIGHTS;
自定義:
[java] view plaincopyprint?- 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的通知無法清除,就是用的這個)
下面附上我做的例子,供大家參考。 裡面包括建立通知、更新通知、清除通知、設定自定義鈴聲、自定義振動、自定義通知檢視等。
附上程式碼:
主類:
[java] view plaincopyprint?- package com.yfz;
- import android.app.Activity;
- import android.app.Notification;
- import android.app.NotificationManager;
- import android.app.PendingIntent;
- import android.content.Intent;
- import android.net.Uri;
- import android.os.Bundle;
- import android.provider.MediaStore.Audio;
- import android.util.Log;
- import android.view.View;
- import android.view.View.OnClickListener;
- import android.widget.Button;
- import android.widget.RemoteViews;
- import android.widget.SeekBar;
- import android.widget.TextView;
- /**
- * Notification
- * @author Administrator
- *
- */
- publicclass Lesson_10 extends Activity {
- //BaseNotification
- private Button bt01;
- //UpdateBaseNotification
- private Button bt02;
- //ClearBaseNotification
- private Button bt03;
- //MediaNotification
- private Button bt04;
- //ClearMediaNotification
- private Button bt05;
- //ClearALL
- private Button bt06;
- //CustomNotification
- private Button bt07;
- //通知管理器
- private NotificationManager nm;
- //通知顯示內容
- private PendingIntent pd;
- @Override
- publicvoid onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- /*載入頁面*/
- setContentView(R.layout.lesson10);
- init();
- }
- privatevoid init() {
- 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);
- Intent intent = new Intent(this,Lesson_10.class);
- pd = PendingIntent.getActivity(Lesson_10.this, 0, intent, 0);
- }
- OnClickListener onclick = new OnClickListener() {
- //BASE Notification ID
- privateint Notification_ID_BASE = 110;
- private Notification baseNF;
- //Notification ID
- privateint Notification_ID_MEDIA = 119;
- private Notification mediaNF;
- @Override
- publicvoid onClick(View v) {
- switch(v.getId()) {
- case R.id.le10bt01:
- //新建狀態列通知
- baseNF = new Notification();
- //設定通知在狀態列顯示的圖示
- baseNF.icon = R.drawable.icon;
- //通知時在狀態列顯示的內容
- baseNF.tickerText = "You clicked BaseNF!";
- //通知的預設引數 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;
- //第二個引數 :下拉狀態列時顯示的訊息標題 expanded message title
- //第三個引數:下拉狀態列時顯示的訊息內容 expanded message text
- //第四個引數:點選該通知時執行頁面跳轉
- baseNF.setLatestEventInfo(Lesson_10.this, "Title01", "Content01", pd);
- //發出狀態列通知
- //The first parameter is the unique ID for the Notification
- // and the second is the Notification object.
- nm.notify(Notification_ID_BASE, baseNF);
- break;
- case R.id.le10bt02:
- //更新通知
- //比如狀態列提示有一條新簡訊,還沒來得及檢視,又來一條新簡訊的提示。
- //此時採用更新原來通知的方式比較。
- //(再重新發一個通知也可以,但是這樣會造成通知的混亂,而且顯示多個通知給使用者,對使用者也不友好)
- baseNF.setLatestEventInfo(Lesson_10.this, "Title02", "Content02", pd);
- nm.notify(Notification_ID_BASE, baseNF);
- break;
- case R.id.le10bt03:
- //清除 baseNF
- nm.cancel(Notification_ID_BASE);
- break;
- case R.id.le10bt04:
- mediaNF = new Notification();
- mediaNF.icon = R.drawable.icon;
- mediaNF.tickerText = "You clicked MediaNF!";
- //自定義聲音
- 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;
- case R.id.le10bt05:
- //清除 mediaNF
- nm.cancel(Notification_ID_MEDIA);
- break;
- case R.id.le10bt06:
- nm.cancelAll();
- break;
- case R.id.le10bt07:
- //自定義下拉檢視,比如下載軟體時,顯示的進度條。
- Notification notification = new Notification();
- notification.icon = R.drawable.icon;
- notification.tickerText = "Custom!";
- RemoteViews contentView = new RemoteViews(getPackageName(), R.layout.custom);
- contentView.setImageViewResource(R.id.image, R.drawable.icon);
- contentView.setTextViewText(R.id.text, "Hello, this message is in a custom expanded view");
- notification.contentView = contentView;
- //使用自定義下拉檢視時,不需要再呼叫setLatestEventInfo()方法
- //但是必須定義 contentIntent
- notification.contentIntent = pd;
- nm.notify(3, notification);
- break;
- }
- }
- };
- }
主頁面:
[xhtml] view plaincopyprint?- <?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>
自定義檢視頁面:
[c-sharp] view plaincopyprint?- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="horizontal"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:padding="3dp"
- >
- <ImageView android:id="@+id/image"
- android:layout_width="wrap_content"
- android:layout_height="fill_parent"
- android:layout_marginRight="10dp"
- />
- <TextView android:id="@+id/text"
- android:layout_width="wrap_content"
- android:layout_height="fill_parent"
- android:textColor="#000"
- />
- </LinearLayout>