通知欄Notification的詳細使用

轉(zhuǎn)載自:http://blog.csdn.net/vipzjyno1/article/details/25248021

在android的應(yīng)用層中,涉及到很多應(yīng)用框架,例如:Service框架,Activity管理機制,Broadcast機制,對話框框架,標題欄框架,狀態(tài)欄框架,通知機制,ActionBar框架等等。

下面就來說說經(jīng)常會使用到通知機制中的通知欄框架(Notificaiton),它適用于交互事件的通知。它是位于頂層可以展開的通知列表。它會時不時的提醒你什么軟件該更新了,什么人發(fā)你微信消息了等。

(網(wǎng)上看了下,全面介紹的文章不多,所以就萌生了寫這篇的念頭,隨便當作回顧筆記。下面我就通過官方文檔、源代碼、書上的一些資料匯總下這一塊的知識,并通過一個通知欄的匯總DEMO讓大家更好的了解這個類的使用,內(nèi)容有點多,可以根據(jù)需求看目錄學習)。

Notificaiton狀態(tài)通知欄:

功能作用

1.顯示接收到短消息、即使消息等信息 (如QQ、微信、新浪、短信)

2.顯示客戶端的推送消息(如有新版本發(fā)布,廣告,推薦新聞等)

3.顯示正在進行的事物(例如:后臺運行的程序)(如音樂播放器、版本更新時候的下載進度等)

思維導圖結(jié)構(gòu)

思維導圖的大體結(jié)構(gòu)(按照各個節(jié)點延伸拓展學習)

Notificaiton -- service ? --?BroadcastReceiver ?-- Intent(flag、Action等屬性應(yīng)用) --PendingIntent

感慨:

一個Notificaiton通知的拓展使用就要涉及與4大組建的配合,所以學好整體的知識體系。

聯(lián)系:

1.由于service 是在后臺運行,所以它意圖做什么我們看不到,可以通過Notificaiton 來顯示提醒(如音樂的后臺播放)。

2.service服務(wù)和BroadcastReceiver廣播相結(jié)合,在加上Notificaiton?顯示(如程序的后臺更新)。

3.Intent作為意圖處理,和Notificaiton的點擊時間緊密結(jié)合在了一起,并且與BroadcastReceiver和service的聯(lián)系也緊密不可以分割。

(service 在后臺之后通過BroadcastReceiver來通知Notificaiton?顯示相關(guān)東西,在通過Intent完成用戶的意圖操作)

相關(guān)文檔:Activity啟動模式 及 Intent Flags 與 棧 的關(guān)聯(lián)分析

對應(yīng)的官方鏈接

設(shè)計文檔 :

官方:http://developer.android.com/design/patterns/notifications.html

譯文:http://adchs.github.io/patterns/notifications.html

使用教程 :http://developer.android.com/training/notify-user/index.html

開發(fā)文檔 :http://developer.android.com/reference/android/app/Notification.html

大體了解

Notification支持文字內(nèi)容顯示、震動三色燈鈴聲等多種提示形式,在默認情況下,Notification僅顯示消息標題消息內(nèi)容送達時間這3項內(nèi)容。以下就是通知的基本布局。

通知的基本布局

普通視圖:

高度64dp

大試圖的通知在展開前也顯示為普通視圖

元素:

1.標題 ? Title/Name

2.大圖標 ?Icon/Photo

3.內(nèi)容文字

4.內(nèi)容信息MESSAGE

5.小圖標 Secondary Icon

6.通知的時間 Timestamp,默認為系統(tǒng)發(fā)出通知的時間,也可通過setWhen()來設(shè)置

相關(guān)分析

狀態(tài)通知欄主要涉及到2個類:Notification 和NotificationManager

Notification為通知信息類,它里面對應(yīng)了通知欄的各個屬性

NotificationManager?: ?是狀態(tài)欄通知的管理類,負責發(fā)通知、清除通知等操作。

注意:NotificationManager 是一個系統(tǒng)Service,所以必須通過getSystemService(NOTIFICATION_SERVICE)方法來獲取,方法如下。


NotificationManager?mNotificationManager?=?(NotificationManager)?getSystemService(NOTIFICATION_SERVICE);


使用步驟:

流程模塊:

第一步:

創(chuàng)建一個通知欄的Builder構(gòu)造類 ?(Create a Notification Builder)

第二步:

定義通知欄的Action ?(Define the Notification's Action)

第三步:

設(shè)置通知欄點擊事件 ? ?(Set the Notification's Click Behavior)

第四步:

通知 ? (Issue the Notification)

代碼模塊:

實現(xiàn)系統(tǒng)默認的通知欄效果:

第一步:獲取狀態(tài)通知欄管理:


NotificationManager?mNotificationManager?=?(NotificationManager)?getSystemService(NOTIFICATION_SERVICE);


第二步:實例化通知欄構(gòu)造器NotificationCompat.Builder:


NotificationCompat.Builder?mBuilder?=newNotificationCompat.Builder(this);


第三步:對Builder進行配置:


mBuilder.setContentTitle("測試標題")//設(shè)置通知欄標題

? ? ? ? .setContentText("測試內(nèi)容")?//設(shè)置通知欄顯示內(nèi)容

? ? ? ? .setContentIntent(getDefalutIntent(Notification.FLAG_AUTO_CANCEL))//設(shè)置通知欄點擊意圖

? ? ? ? //??.setNumber(number)?//設(shè)置通知集合的數(shù)量

? ? ? ?.setTicker("測試通知來啦")//通知首次出現(xiàn)在通知欄,帶上升動畫效果的

? ? ? ?.setWhen(System.currentTimeMillis())//通知產(chǎn)生的時間,會在通知信息里顯示,一般是系統(tǒng)獲取到的時間

? ? ? ?.setPriority(Notification.PRIORITY_DEFAULT)//設(shè)置該通知優(yōu)先級

? ? ? ?//??.setAutoCancel(true)//設(shè)置這個標志當用戶單擊面板就可以讓通知將自動取消

? ? ? .setOngoing(false)//ture,設(shè)置他為一個正在進行的通知。他們通常是用來表示一個后臺任務(wù),用戶積極參與(如播放音樂)或以某種方式正在等待,因此占用設(shè)備(如一個文件下載,同步操作,主動網(wǎng)絡(luò)連接)

? ? ? ?.setDefaults(Notification.DEFAULT_VIBRATE)//向通知添加聲音、閃燈和振動效果的最簡單、最一致的方式是使用當前的用戶默認設(shè)置,使用defaults屬性,可以組合

? ? ? ? //Notification.DEFAULT_ALL??Notification.DEFAULT_SOUND?添加聲音?//?requires?VIBRATE?permission

? ? ? ?.setSmallIcon(R.drawable.ic_launcher);//設(shè)置通知小ICON


對應(yīng)的各個方法的屬性(部分方法以上代碼中已經(jīng)作注釋,就不再介紹):

(1)方法:設(shè)置提醒標志符Flags

功能:提醒標志符,向通知添加聲音、閃燈和振動效果等設(shè)置達到通知提醒效果,可以組合多個屬性

有2種設(shè)置方法:

1.實例化通知欄之后通過給他添加.flags屬性賦值。


Notification?notification?=?mBuilder.build();

notification.flags?=?Notification.FLAG_AUTO_CANCEL;


2.通過setContentIntent(PendingIntentintent)方法中的意圖設(shè)置對應(yīng)的flags


publicPendingIntent?getDefalutIntent(intflags){

? ? ? ? PendingIntent?pendingIntent=?PendingIntent.getActivity(this,1,newIntent(),?flags);

? ? ? ? ?return pendingIntent;

}


提醒標志符成員:

Notification.FLAG_SHOW_LIGHTS ? ? ? ? ? ? ?//三色燈提醒,在使用三色燈提醒時候必須加該標志符

Notification.FLAG_ONGOING_EVENT ? ? ? ? ?//發(fā)起正在運行事件(活動中)

Notification.FLAG_INSISTENT//讓聲音、振動無限循環(huán),直到用戶響應(yīng)(取消或者打開)

Notification.FLAG_ONLY_ALERT_ONCE//發(fā)起Notification后,鈴聲和震動均只執(zhí)行一次

Notification.FLAG_AUTO_CANCEL ? ? ?//用戶單擊通知后自動消失

Notification.FLAG_NO_CLEAR ? ? ? ? ?//只有全部清除時,Notification才會清除,不清楚該通知(QQ的通知無法清除,就是用的這個)

Notification.FLAG_FOREGROUND_SERVICE ? ?//表示正在運行的服務(wù)

(2)方法:.setDefaults(int defaults) ? ? (NotificationCompat.Builder中的方法,用于提示)

功能:向通知添加聲音、閃燈和振動效果的最簡單、使用默認(defaults)屬性,可以組合多個屬性(和方法1中提示效果一樣的)

對應(yīng)屬性:

Notification.DEFAULT_VIBRATE ? ?//添加默認震動提醒 ?需要 VIBRATE permission

Notification.DEFAULT_SOUND ? ?//?添加默認聲音提醒

Notification.DEFAULT_LIGHTS//?添加默認三色燈提醒

Notification.DEFAULT_ALL//?添加默認以上3種全部提醒

(3)方法:setVibrate(long[] pattern)

功能:設(shè)置震動方式。

使用:


.setVibrate(newlong[]?{0,300,500,700});


實現(xiàn)效果:延遲0ms,然后振動300ms,在延遲500ms,接著在振動700ms。

以上方法的還有種寫法是


mBuilder.build().vibrate?=newlong[]?{0,300,500,700};


以此類推,2種寫法都可以。

如果希望設(shè)置默認振動方式,設(shè)置了方法(2)中默認為DEFAULT_VIBRATE 即可。

(4)方法:.setLights(intledARGB,intledOnMS,intledOffMS)

功能:android支持三色燈提醒,這個方法就是設(shè)置不同場景下的不同顏色的燈。

描述:其中l(wèi)edARGB 表示燈光顏色、?ledOnMS 亮持續(xù)時間、ledOffMS 暗的時間。

注意:1)只有在設(shè)置了標志符Flags為Notification.FLAG_SHOW_LIGHTS的時候,才支持三色燈提醒。

2)這邊的顏色跟設(shè)備有關(guān),不是所有的顏色都可以,要看具體設(shè)備。

使用:


.setLights(0xff0000ff,300,0)


同理,以下方法也可以設(shè)置同樣效果:


Notification?notify?=?mBuilder.build();

notify.flags?=?Notification.FLAG_SHOW_LIGHTS;

notify.ledARGB?=0xff0000ff;

notify.ledOnMS?=300;

notify.ledOffMS?=300;


如果希望使用默認的三色燈提醒,設(shè)置了方法(2)中默認為DEFAULT_LIGHTS即可。

(5)方法:.setSound(Urisound)

功能:設(shè)置默認或則自定義的鈴聲,來提醒。


//獲取默認鈴聲

.setDefaults(Notification.DEFAULT_SOUND)

//獲取自定義鈴聲

.setSound(Uri.parse("file:///sdcard/xx/xx.mp3"))

//獲取Android多媒體庫內(nèi)的鈴聲

.setSound(Uri.withAppendedPath(Audio.Media.INTERNAL_CONTENT_URI,"5"))


同理相同效果的另一種設(shè)置方法這邊就不講, 和上面的都是一樣的。

(6)方法:.setPriority(int pri)

功能:設(shè)置優(yōu)先級

對應(yīng)優(yōu)先級描述如下圖:


對應(yīng)屬性(作用看上圖就可知道):

Notification.PRIORITY_DEFAULT

Notification.PRIORITY_HIGH

Notification.PRIORITY_LOW

Notification.PRIORITY_MAX

Notification.PRIORITY_MIN

(7)方法:setOngoing(boolean ongoing)

功能:設(shè)置為ture,表示它為一個正在進行的通知。他們通常是用來表示一個后臺任務(wù),用戶積極參與(如播放音樂)或以某種方式正在等待,因此占用設(shè)備(如一個文件下載,同步操作,主動網(wǎng)絡(luò)連接)

(8)方法:setProgress(int max, int progress,boolean indeterminate)

屬性:max:進度條最大數(shù)值 ?、progress:當前進度、indeterminate:表示進度是否不確定,true為不確定,如下第3幅圖所示 ?,false為確定下第1幅圖所示

功能:設(shè)置帶進度條的通知,可以在下載中使用

效果圖如下:

注意:此方法在4.0及以后版本才有用,如果為早期版本:需要自定義通知布局,其中包含ProgressBar視圖

使用:如果為確定的進度條:調(diào)用setProgress(max, progress, false)來設(shè)置通知,在更新進度的時候在此發(fā)起通知更新progress,并且在下載完成后要移除進度條,通過調(diào)用setProgress(0, 0, false)既可。

如果為不確定(持續(xù)活動)的進度條,這是在處理進度無法準確獲知時顯示活動正在持續(xù),所以調(diào)用setProgress(0, 0, true),操作結(jié)束時,調(diào)用setProgress(0, 0, false)并更新通知以移除指示條

第四步:設(shè)置通知欄PendingIntent(點擊動作事件等都包含在這里)

在第三步中,沒有提到一個方法,就是setContentIntent(PendingIntentintent)這個方法,這里拿到這里講。

知識點

1)什么是PendingIntent

PendingIntent和Intent略有不同,它可以設(shè)置執(zhí)行次數(shù),主要用于遠程服務(wù)通信、鬧鈴、通知、啟動器、短信中,在一般情況下用的比較少。

2)PendingIntent什么用

Notification支持多種Intent來響應(yīng)單擊事件、消除事件、處理緊急狀態(tài)的全屏事件等。

這里就用到了setContentIntent(PendingIntentintent)來處理以上這么多的事件。

3)相關(guān)屬性和方法

屬性:

PendingIntent的位標識符:

FLAG_ONE_SHOT ? 表示返回的PendingIntent僅能執(zhí)行一次,執(zhí)行完后自動取消

FLAG_NO_CREATE表示如果描述的PendingIntent不存在,并不創(chuàng)建相應(yīng)的PendingIntent,而是返回NULL

FLAG_CANCEL_CURRENT表示相應(yīng)的PendingIntent已經(jīng)存在,則取消前者,然后創(chuàng)建新的PendingIntent,這個有利于數(shù)據(jù)保持為最新的,可以用于即時通信的通信場景

FLAG_UPDATE_CURRENT ? ? 表示更新的PendingIntent

方法:

可以看出,它支持多種相應(yīng)方式,有Activity、Broadcast、Service,就根據(jù)你自身需求去選擇。

在各種情況下情況下它還會根據(jù)各種情況出發(fā)效果:

contentIntent:在通知窗口區(qū)域,Notification被單擊時的響應(yīng)事件由該intent觸發(fā);

deleteIntent:當用戶點擊全部清除按鈕時,響應(yīng)該清除事件的Intent;

fullScreenIntent:響應(yīng)緊急狀態(tài)的全屏事件(例如來電事件),也就是說通知來的時候,跳過在通知區(qū)域點擊通知這一步,直接執(zhí)行fullScreenIntent代表的事件。

例如:在執(zhí)行了點擊通知之后要跳轉(zhuǎn)到指定的XXX的Activity的時候,可以設(shè)置以下方法來相應(yīng)點擊事件:


Intent?intent?=newIntent(context,XXX.class);

PendingIntent?pendingIntent?=?PendingIntent.getActivity(context,0,?intent,0);

mBuilder.setContentIntent(pendingIntent)


例如:在執(zhí)行了清空全部的通知操作時候,可以設(shè)置以下方法來相應(yīng)這個事件:

采用setDeleteIntent(PendingIntentintent)方法或按照以下寫法


Intent?deleteIntent?=newIntent();

deleteIntent.setClass(context,?XXXReceiver.class);

deleteIntent.setAction(DELETE_ACTION);

notification.deleteIntent?=?PendingIntent.getBroadcast(context,0,?deleteIntent,0);


例如:在響應(yīng)緊急事件(如來電)時候,可以設(shè)置以下方法來相應(yīng)這個事件:

采用setFullScreenIntent(PendingIntentintent, boolean highPriority)

第五步,最簡單的一部,發(fā)送通知請求


mNotificationManager.notify(notifyId,?mBuilder.build());


拓展

實現(xiàn)自定義的通知欄效果:

這里要用到RemoteViews這個類。實現(xiàn)以下2種自定義布局。

注意:

Notification的自定義布局是RemoteViews,和其他RemoteViews一樣,在自定義視圖布局文件中,僅支持FrameLayout、LinearLayout、RelativeLayout三種布局控件和AnalogClock、Chronometer、Button、ImageButton、ImageView、ProgressBar、TextView、ViewFlipper、ListView、GridView、StackView和AdapterViewFlipper這些顯示控件,不支持這些類的子類或Android提供的其他控件。否則會引起ClassNotFoundException異常

步驟如下:

1)創(chuàng)建自定義視圖

2)獲取遠程視圖對象(注:Notification的contentView不能為空)

3)設(shè)置PendingIntent(來響應(yīng)各種事件)

4)發(fā)起Notification

大體4步驟這里就不詳細說了,下面就把DEMO中的列子拿出來說下

樣式:

1.自定義帶按鈕通知欄(如下樣式)

正在進行的

“正在進行的”通知使用戶了解正在運行的后臺進程。例如,音樂播放器可以顯示正在播放的音樂。也可以用來顯示需要長時間處理的操作,例如下載或編碼視頻。“正在進行的”通知不能被手動刪除。

實現(xiàn)方法如下:


/**

*?帶按鈕的通知欄

*/

publicvoidshowButtonNotify(){

NotificationCompat.Builder?mBuilder?=newBuilder(this);

RemoteViews?mRemoteViews?=newRemoteViews(getPackageName(),?R.layout.view_custom_button);

mRemoteViews.setImageViewResource(R.id.custom_song_icon,?R.drawable.sing_icon);

//API3.0?以上的時候顯示按鈕,否則消失

mRemoteViews.setTextViewText(R.id.tv_custom_song_singer,"周杰倫");

mRemoteViews.setTextViewText(R.id.tv_custom_song_name,"七里香");

//如果版本號低于(3。0),那么不顯示按鈕

if(BaseTools.getSystemVersion()?<=9){

mRemoteViews.setViewVisibility(R.id.ll_custom_button,?View.GONE);

}else{

mRemoteViews.setViewVisibility(R.id.ll_custom_button,?View.VISIBLE);

}

//

if(isPlay){

mRemoteViews.setImageViewResource(R.id.btn_custom_play,?R.drawable.btn_pause);

}else{

mRemoteViews.setImageViewResource(R.id.btn_custom_play,?R.drawable.btn_play);

}

//點擊的事件處理

Intent?buttonIntent?=newIntent(ACTION_BUTTON);

/*?上一首按鈕?*/

buttonIntent.putExtra(INTENT_BUTTONID_TAG,?BUTTON_PREV_ID);

//這里加了廣播,所及INTENT的必須用getBroadcast方法

PendingIntent?intent_prev?=?PendingIntent.getBroadcast(this,1,?buttonIntent,?PendingIntent.FLAG_UPDATE_CURRENT);

mRemoteViews.setOnClickPendingIntent(R.id.btn_custom_prev,?intent_prev);

/*?播放/暫停??按鈕?*/

buttonIntent.putExtra(INTENT_BUTTONID_TAG,?BUTTON_PALY_ID);

PendingIntent?intent_paly?=?PendingIntent.getBroadcast(this,2,?buttonIntent,?PendingIntent.FLAG_UPDATE_CURRENT);

mRemoteViews.setOnClickPendingIntent(R.id.btn_custom_play,?intent_paly);

/*?下一首?按鈕??*/

buttonIntent.putExtra(INTENT_BUTTONID_TAG,?BUTTON_NEXT_ID);

PendingIntent?intent_next?=?PendingIntent.getBroadcast(this,3,?buttonIntent,?PendingIntent.FLAG_UPDATE_CURRENT);

mRemoteViews.setOnClickPendingIntent(R.id.btn_custom_next,?intent_next);

mBuilder.setContent(mRemoteViews)

.setContentIntent(getDefalutIntent(Notification.FLAG_ONGOING_EVENT))

.setWhen(System.currentTimeMillis())//?通知產(chǎn)生的時間,會在通知信息里顯示

.setTicker("正在播放")

.setPriority(Notification.PRIORITY_DEFAULT)//?設(shè)置該通知優(yōu)先級

.setOngoing(true)

.setSmallIcon(R.drawable.sing_icon);

Notification?notify?=?mBuilder.build();

notify.flags?=?Notification.FLAG_ONGOING_EVENT;

mNotificationManager.notify(notifyId,?notify);

}


注意:帶按鈕的布局相應(yīng)點擊事件在3.0以下版本沒有用,所以這邊作了系統(tǒng)版本判斷,來顯示消失按鈕。

2.自定義不帶按鈕通知欄

實現(xiàn)方法如下:


//先設(shè)定RemoteViews

RemoteViews?view_custom?=newRemoteViews(getPackageName(),?R.layout.view_custom);

//設(shè)置對應(yīng)IMAGEVIEW的ID的資源圖片

view_custom.setImageViewResource(R.id.custom_icon,?R.drawable.icon);

//??????view_custom.setInt(R.id.custom_icon,"setBackgroundResource",R.drawable.icon);

view_custom.setTextViewText(R.id.tv_custom_title,"今日頭條");

view_custom.setTextViewText(R.id.tv_custom_content,"金州勇士官方宣布球隊已經(jīng)解雇了主帥馬克-杰克遜,隨后宣布了最后的結(jié)果。");


之后調(diào)用:


mBuilder.setContent(view_custom)


來設(shè)定自定義的這個布局。

實現(xiàn):大視圖風格通知(注:4.1之前的版本不支持大視圖)

只在通知被展開時顯示

何時展開:通知處在頂端,或者用戶通過收拾展開

收件箱風格的通知:

相比普通視圖,只多出:7. 詳情區(qū)域

效果圖如下:

詳情區(qū)域根據(jù)用途可有多種風格:

1.NotificationCompat.BigPictureStyle?大圖片風格:詳情區(qū)域包含一個256dp高度的位圖

2.NotificationCompat.BigTextStyle大文字風格:顯示一個大的文字塊

3.NotificationCompat.InboxStyle ?收件箱風格:顯示多行文字

各種風格都具有以下常規(guī)視圖不具有的內(nèi)容選項:

1.大標題:在展開視圖時替代普通視圖的標記

2.總結(jié)文字:允許你在詳情區(qū)域之下增加一行內(nèi)容

拿收件箱風格為例,實現(xiàn)代碼如下:


NotificationCompat.BigPictureStyle?inboxStyle?=newNotificationCompat.InboxStyle();

String[]?events?=newString[5];

//?Sets?a?title?for?the?Inbox?style?big?view

inboxStyle.setBigContentTitle("大視圖內(nèi)容:");

//?Moves?events?into?the?big?view

for(inti=0;?i?<?events.length;?i++)?{

inboxStyle.addLine(events[i]);

}

mBuilder.setContentTitle("測試標題")

.setContentText("測試內(nèi)容")

//??????????????.setNumber(number)//顯示數(shù)量

.setStyle(inboxStyle)//設(shè)置風格

.setTicker("測試通知來啦");


開發(fā)中碰到的問題

(注:下面所指的低版本是指2.3及2.3以下版本)

1.如何取消掉通知欄上的通知

(1)設(shè)置對應(yīng)的flags,讓用戶點擊既被消除:


notification.flags = FLAG_AUTO_CANCEL;


(2) 通過手動消除某項或則全部通知


mNotificationMgr.cancle(NOTIFICATION_ID);//消除對應(yīng)ID的通知

mNotificationMgr.cancleAll();//消除創(chuàng)建的所有通知


2.低版本中的部分方法已經(jīng)被棄用的

(1)Notification.Builder(this).getNotification()

(2)mNotification.setLatestEventInfo(this, "title", "content", null);

這些方法都已經(jīng)被啟用,雖然還有效果,可是不建議使用。所以開發(fā)過程中盡量使用NotificationCompat.Builder(this)的構(gòu)建方法去創(chuàng)建一個通知類。

3.低版本中會報的錯誤及解決方案:

(1)錯誤代碼:java.lang.IllegalArgumentException: contentIntent required: pkg=com.example.notifications id=100 notification=Notification(vibrate=default,sound=null,defaults=0x2,flags=0x0)

解決方案:如果在高版本不會出錯,而在2.3上面報了這個錯誤,通過開發(fā)文檔中的以下知道你可以找打:

For this reason, you should always ensure that UI controls in a notification are also available in anActivityin your app, and you should always start thatActivitywhen users click the notification. To do this, use thesetContentIntent()method.

你就應(yīng)該知道,缺少了setContentIntent()這個方法,在2.3及更低的版本中,必須給它設(shè)置設(shè)置contentIntent,如果你點擊沒有意圖,可以在賦值的的Intent中設(shè)置為new Intent()既可,切記contentIntent不能為空。

代碼如下:


publicPendingIntent?getDefalutIntent(intflags){

? ? ? ? ?PendingIntent?pendingIntent=?PendingIntent.getActivity(this,1,newIntent(),?flags);

? ? ? ? ?return pendingIntent;

}


(2)錯誤代碼:android.app.RemoteServiceException: Bad notification posted from package com.example.notifications: Couldn't expand RemoteViews for: StatusBarNotification(package=com.example.notifications id=101 tag=null notification=Notification(vibrate=null,sound=null,defaults=0x0,flags=0x2))

解決方法:

在自定義的時候,發(fā)現(xiàn)了這個問題,解決:每次更新時都必須把RemoteViews給new出來才行,不能利用已有的notification.contentView直接操作!

4.低版本中,自定義的通知欄中如果帶有按鈕,可能按鈕點擊事件會失靈

解決方法:看其它的應(yīng)用,好像在低版本都會隱藏掉那些按鈕,就是為了不影響用戶體驗,所以應(yīng)該就這么解決,判斷版本號在去決定是否現(xiàn)在按鈕。

5.低版本中,自定義布局中的字體顏色看不清

如右圖:

解決方案:

由于2.3及之前版本,背景設(shè)是白色的那我們定義字體顏色為系統(tǒng)預(yù)設(shè)的顏色:


?android:attr/textColorPrimary


在資源的src/values目錄中的style.xml文件中設(shè)置它標題和內(nèi)容的樣式為:

在2.3之后的版本中(即API >=9的版本中),在資源文件下的src/values-v9目錄中的style.xml文件中設(shè)置它標題和內(nèi)容的樣式為:

最后賦給自定義布局中的對應(yīng)標題和內(nèi)容對應(yīng)的style即可。

對應(yīng)解決網(wǎng)址:

1.http://stackoverflow.com/questions/6250356/how-to-use-default-notification-style

2.http://stackoverflow.com/questions/4867338/custom-notification-layouts-and-text-colors/7320604#7320604

3.http://developer.android.com/guide/topics/ui/notifiers/notifications.html#CustomExpandedView ? (官方文檔)

http://developer.android.com/about/versions/android-2.2-highlights.html

6.低版本中mBuilder.setProgress(100, progress, false);沒用,不顯示進度條

解決方法:此方法在4.0及以后版本才有用,如果為早期版本:需要自定義通知布局,其中包含ProgressBar視圖

7.自定義布局的時候,不同版本方法不一樣。(弄了半天,在2.3版本不顯示,原來是方法不兼容)

2.3及2.3之前:

通過


Notification?notify?=?mBuilder.build();

notify.contentView?=?view_custom;

mNotificationManager.notify(notifyId,?notify)


方法賦予VIEW。

2.3之后:

通過Builder以下方法賦于自定義布局。

mBuilder.setContent(view_custom)

DEMO截圖:

DEMO下載:下載地址

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • 原文出處: http://www.androidchina.net/6174.html Notification在...
    木木00閱讀 12,393評論 3 32
  • 通知(Notification)這個功能對于我們來說非常的常見。打開手機的時候,各種軟件的推送消息蜂擁而至,然后我...
    憶念成風閱讀 3,352評論 2 10
  • 基本使用 1.獲取 NotificationManager 實例2.實例化 NotificationCompat....
    不需要任何閱讀 873評論 0 7
  • Notification簡介 通知是在常規(guī)UI界面之外向用戶展示消息的工具,當系統(tǒng)發(fā)出通知時,它會以圖表的形式顯示...
    Cris_Ma閱讀 6,940評論 2 10
  • 楊戩拉過敖寸心的手掌仔細看了一遍,一抬頭就對上敖寸心得意洋洋的表情:“你悟出來了?”楊戩的聲音也透著驚喜,他是知道...
    輕映閱讀 625評論 0 0