Notification與NotificationManager詳細介紹
更新時間:2012年11月12日 13:55:35 作者:
在Android系統(tǒng)中,發(fā)一個狀態(tài)欄通知還是很方便的。下面我們就來看一下,怎么發(fā)送狀態(tài)欄通知,狀態(tài)欄通知又有哪些參數(shù)可以設(shè)置
在Android系統(tǒng)中,發(fā)一個狀態(tài)欄通知還是很方便的。下面我們就來看一下,怎么發(fā)送狀態(tài)欄通知,狀態(tài)欄通知又有哪些參數(shù)可以設(shè)置?
首先,發(fā)送一個狀態(tài)欄通知必須用到兩個類:NotificationManager、Notification。
NotificationManager:是狀態(tài)欄通知的管理類,負責發(fā)通知、清楚通知等。
NotificationManager是一個系統(tǒng)Service,必須通過getSystemService()方法來獲取。
NotificationManagernm=(NotificationManager)getSystemService(NOTIFICATION_SERVICE);
Notification:是具體的狀態(tài)欄通知對象,可以設(shè)置icon、文字、提示聲音、振動等等參數(shù)。
下面是設(shè)置一個通知需要的基本參數(shù):
Anicon(通知的圖標)
Atitleandexpandedmessage(通知的標題和內(nèi)容)
APendingIntent(點擊通知執(zhí)行頁面跳轉(zhuǎn))
一、創(chuàng)建Notification
通過NotificationManager的notify(int,Notification)方法來啟動Notification。
第一個參數(shù)唯一的標識該Notification,第二個參數(shù)就是Notification對象。
二、更新Notification
調(diào)用Notification的setLatestEventInfo方法來更新內(nèi)容,然后再調(diào)用NotificationManager的notify()方法即可。(具體可以看下面的實例)
三、刪除Notification
通過NotificationManager的cancel(int)方法,來清除某個通知。其中參數(shù)就是Notification的唯一標識ID。
當然也可以通過cancelAll()來清除狀態(tài)欄所有的通知。
四、Notification設(shè)置(振動、鈴聲等)
1.基本設(shè)置:
//新建狀態(tài)欄通知
baseNF=newNotification();
//設(shè)置通知在狀態(tài)欄顯示的圖標
baseNF.icon=R.drawable.icon;
//通知時在狀態(tài)欄顯示的內(nèi)容
baseNF.tickerText="YouclickedBaseNF!";
//通知的默認參數(shù)DEFAULT_SOUND,DEFAULT_VIBRATE,DEFAULT_LIGHTS.
//如果要全部采用默認值,用DEFAULT_ALL.
//此處采用默認聲音
baseNF.defaults=Notification.DEFAULT_SOUND;
//第二個參數(shù):下拉狀態(tài)欄時顯示的消息標題expandedmessagetitle
//第三個參數(shù):下拉狀態(tài)欄時顯示的消息內(nèi)容expandedmessagetext
//第四個參數(shù):點擊該通知時執(zhí)行頁面跳轉(zhuǎn)
baseNF.setLatestEventInfo(Lesson_10.this,"Title01","Content01",pd);
//發(fā)出狀態(tài)欄通知
//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");
上面這種方法,使用的是自己的鈴聲,如果想用系統(tǒng)自帶的鈴聲,可以這樣:
notification.sound=Uri.withAppendedPath(Audio.Media.INTERNAL_CONTENT_URI,"6");
需要注意一點,如果default、sound同時出現(xiàn),那么sound無效,會使用默認鈴聲。
默認情況下,通知的聲音播放一遍就會結(jié)束。如果你想讓聲音循環(huán)播放,需要為flags參數(shù)加上FLAG_INSISTENT。這樣聲音會到用戶響應(yīng)才結(jié)束,比如下拉狀態(tài)欄。
notification.flags|=notification.FLAG_INSISTENT;
3.添加振動
如果是使用默認的振動方式,那么同樣也是使用default。
notification.defaults|=Notification.DEFAULT_VIBRATE;
當然也可以自己定義振動形式,這邊需要用到Long型數(shù)組。
long[]vibrate={0,100,200,300};
notification.vibrate=vibrate;
這邊的Long型數(shù)組中,第一個參數(shù)是開始振動前等待的時間,第二個參數(shù)是第一次振動的時間,第三個參數(shù)是第二次振動的時間,以此類推,隨便定義多長的數(shù)組。但是采用這種方法,沒有辦法做到重復振動。
同樣,如果default、vibrate同時出現(xiàn)時,會采用默認形式。
另外還需要注意一點:使用振動器時需要權(quán)限,如下:
<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;
其中l(wèi)edARGB表示燈光顏色、ledOnMS亮持續(xù)時間、ledOffMS暗的時間。
注意:這邊的顏色跟設(shè)備有關(guān),不是所有的顏色都可以,要看具體設(shè)備。
5.其他有用的設(shè)置:
flags:
Notification.FLAG_INSISTENT;//讓聲音、振動無限循環(huán),直到用戶響應(yīng)
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;
//使用自定義下拉視圖時,不需要再調(diào)用setLatestEventInfo()方法
//但是必須定義contentIntent
notification.contentIntent=pd;
nm.notify(3,notification);
首先,發(fā)送一個狀態(tài)欄通知必須用到兩個類:NotificationManager、Notification。
NotificationManager:是狀態(tài)欄通知的管理類,負責發(fā)通知、清楚通知等。
NotificationManager是一個系統(tǒng)Service,必須通過getSystemService()方法來獲取。
NotificationManagernm=(NotificationManager)getSystemService(NOTIFICATION_SERVICE);
Notification:是具體的狀態(tài)欄通知對象,可以設(shè)置icon、文字、提示聲音、振動等等參數(shù)。
下面是設(shè)置一個通知需要的基本參數(shù):
Anicon(通知的圖標)
Atitleandexpandedmessage(通知的標題和內(nèi)容)
APendingIntent(點擊通知執(zhí)行頁面跳轉(zhuǎn))
一、創(chuàng)建Notification
通過NotificationManager的notify(int,Notification)方法來啟動Notification。
第一個參數(shù)唯一的標識該Notification,第二個參數(shù)就是Notification對象。
二、更新Notification
調(diào)用Notification的setLatestEventInfo方法來更新內(nèi)容,然后再調(diào)用NotificationManager的notify()方法即可。(具體可以看下面的實例)
三、刪除Notification
通過NotificationManager的cancel(int)方法,來清除某個通知。其中參數(shù)就是Notification的唯一標識ID。
當然也可以通過cancelAll()來清除狀態(tài)欄所有的通知。
四、Notification設(shè)置(振動、鈴聲等)
1.基本設(shè)置:
復制代碼 代碼如下:
//新建狀態(tài)欄通知
baseNF=newNotification();
//設(shè)置通知在狀態(tài)欄顯示的圖標
baseNF.icon=R.drawable.icon;
//通知時在狀態(tài)欄顯示的內(nèi)容
baseNF.tickerText="YouclickedBaseNF!";
//通知的默認參數(shù)DEFAULT_SOUND,DEFAULT_VIBRATE,DEFAULT_LIGHTS.
//如果要全部采用默認值,用DEFAULT_ALL.
//此處采用默認聲音
baseNF.defaults=Notification.DEFAULT_SOUND;
//第二個參數(shù):下拉狀態(tài)欄時顯示的消息標題expandedmessagetitle
//第三個參數(shù):下拉狀態(tài)欄時顯示的消息內(nèi)容expandedmessagetext
//第四個參數(shù):點擊該通知時執(zhí)行頁面跳轉(zhuǎn)
baseNF.setLatestEventInfo(Lesson_10.this,"Title01","Content01",pd);
//發(fā)出狀態(tài)欄通知
//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");
上面這種方法,使用的是自己的鈴聲,如果想用系統(tǒng)自帶的鈴聲,可以這樣:
復制代碼 代碼如下:
notification.sound=Uri.withAppendedPath(Audio.Media.INTERNAL_CONTENT_URI,"6");
需要注意一點,如果default、sound同時出現(xiàn),那么sound無效,會使用默認鈴聲。
默認情況下,通知的聲音播放一遍就會結(jié)束。如果你想讓聲音循環(huán)播放,需要為flags參數(shù)加上FLAG_INSISTENT。這樣聲音會到用戶響應(yīng)才結(jié)束,比如下拉狀態(tài)欄。
復制代碼 代碼如下:
notification.flags|=notification.FLAG_INSISTENT;
3.添加振動
如果是使用默認的振動方式,那么同樣也是使用default。
復制代碼 代碼如下:
notification.defaults|=Notification.DEFAULT_VIBRATE;
當然也可以自己定義振動形式,這邊需要用到Long型數(shù)組。
復制代碼 代碼如下:
long[]vibrate={0,100,200,300};
notification.vibrate=vibrate;
這邊的Long型數(shù)組中,第一個參數(shù)是開始振動前等待的時間,第二個參數(shù)是第一次振動的時間,第三個參數(shù)是第二次振動的時間,以此類推,隨便定義多長的數(shù)組。但是采用這種方法,沒有辦法做到重復振動。
同樣,如果default、vibrate同時出現(xiàn)時,會采用默認形式。
另外還需要注意一點:使用振動器時需要權(quán)限,如下:
復制代碼 代碼如下:
<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;
其中l(wèi)edARGB表示燈光顏色、ledOnMS亮持續(xù)時間、ledOffMS暗的時間。
注意:這邊的顏色跟設(shè)備有關(guān),不是所有的顏色都可以,要看具體設(shè)備。
5.其他有用的設(shè)置:
復制代碼 代碼如下:
flags:
Notification.FLAG_INSISTENT;//讓聲音、振動無限循環(huán),直到用戶響應(yīng)
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;
//使用自定義下拉視圖時,不需要再調(diào)用setLatestEventInfo()方法
//但是必須定義contentIntent
notification.contentIntent=pd;
nm.notify(3,notification);
您可能感興趣的文章:
- Android界面 NotificationManager使用Bitmap做圖標
- Android中關(guān)于Notification及NotificationManger的詳解
- android notification 的總結(jié)分析
- android中創(chuàng)建通知欄Notification代碼實例
- Android中Notification用法實例總結(jié)
- Android中通過Notification&NotificationManager實現(xiàn)消息通知
- Android編程開發(fā)之NotiFication用法詳解
- Android中Notification的用法匯總
相關(guān)文章
Android?ViewPager實現(xiàn)左右滑動翻頁效果
這篇文章主要為大家詳細介紹了Android?ViewPager實現(xiàn)左右滑動翻頁效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12
Android實現(xiàn)讀取掃碼槍內(nèi)容(條形碼)
這篇文章主要為大家詳細介紹了Android實現(xiàn)讀取掃碼槍內(nèi)容、條形碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
android 檢查網(wǎng)絡(luò)連接狀態(tài)實現(xiàn)步驟
android 如何檢查網(wǎng)絡(luò)連接狀態(tài),是android開發(fā)中一個常見的問題,本文將介紹如何實現(xiàn),需要的朋友可以參考下2012-12-12
Android 使用jarsigner給apk簽名的方法詳細介紹
這篇文章主要介紹了Android 使用jarsigner給apk簽名的方法詳細介紹的相關(guān)資料,APP 完成需要在一些APP 商店進行上傳審核,供用戶下載使用,APP 需要簽名認證,需要的朋友可以參考下2016-12-12
Android ExpandableListView實現(xiàn)下拉刷新和加載更多效果
這篇文章主要為大家詳細介紹了Android ExpandableListView實現(xiàn)下拉刷新和加載更多效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06
Android開發(fā)教程之ContentProvider數(shù)據(jù)存儲
這篇文章主要介紹了Android開發(fā)教程之ContentProvider數(shù)據(jù)存儲的相關(guān)資料,需要的朋友可以參考下2016-12-12

