-
package com.yzw.android;
- import android.app.Activity;
- import android.app.Notification;
- import android.app.NotificationManager;
- import android.app.PendingIntent;
- import android.content.Context;
- import android.content.Intent;
- import android.os.Bundle;
- import android.view.View;
- import android.widget.RemoteViews;
- public class MainActivity extends Activity {
- private static final int NOTIFICATION_FLAG = 1;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- }
- public void notificationMethod(View view) {
- // 在Android進行通知處理,首先需要重系統哪裏獲得通知管理器NotificationManager,它是一個系統Service。
- NotificationManager manager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
- switch (view.getId()) {
- // 默認通知
- case R.id.btn1:
- // 創建一個PendingIntent,和Intent類似,不同的是由於不是馬上調用,需要在下拉狀態條出發的activity,所以採用的是PendingIntent,即點擊Notification跳轉啓動到哪個Activity
- PendingIntent pendingIntent = PendingIntent.getActivity(this, 0,
- new Intent(this, MainActivity.class), 0);
- // 下面需兼容Android 2.x版本是的處理方式
- // Notification notify1 = new Notification(R.drawable.message,
- // "TickerText:" + "您有新短消息,請注意查收!", System.currentTimeMillis());
- Notification notify1 = new Notification();
- notify1.icon = R.drawable.message;
- notify1.tickerText = "TickerText:您有新短消息,請注意查收!";
- notify1.when = System.currentTimeMillis();
- notify1.setLatestEventInfo(this, "Notification Title",
- "This is the notification message", pendingIntent);
- notify1.number = 1;
- notify1.flags |= Notification.FLAG_AUTO_CANCEL; // FLAG_AUTO_CANCEL表明當通知被用戶點擊時,通知將被清除。
- // 通過通知管理器來發起通知。如果id不同,則每click,在statu那裏增加一個提示
- manager.notify(NOTIFICATION_FLAG, notify1);
- break;
- // 默認通知 API11及之後可用
- case R.id.btn2:
- PendingIntent pendingIntent2 = PendingIntent.getActivity(this, 0,
- new Intent(this, MainActivity.class), 0);
- // 通過Notification.Builder來創建通知,注意API Level
- // API11之後才支持
- Notification notify2 = new Notification.Builder(this)
- .setSmallIcon(R.drawable.message) // 設置狀態欄中的小圖片,尺寸一般建議在24×24,這個圖片同樣也是在下拉狀態欄中所顯示,如果在那裏需要更換更大的圖片,可以使用setLargeIcon(Bitmap
- // icon)
- .setTicker("TickerText:" + "您有新短消息,請注意查收!")// 設置在status
- // bar上顯示的提示文字
- .setContentTitle("Notification Title")// 設置在下拉status
- // bar後Activity,本例子中的NotififyMessage的TextView中顯示的標題
- .setContentText("This is the notification message")// TextView中顯示的詳細內容
- .setContentIntent(pendingIntent2) // 關聯PendingIntent
- .setNumber(1) // 在TextView的右方顯示的數字,可放大圖片看,在最右側。這個number同時也起到一個序列號的左右,如果多個觸發多個通知(同一ID),可以指定顯示哪一個。
- .getNotification(); // 需要注意build()是在API level
- // 16及之後增加的,在API11中可以使用getNotificatin()來代替
- notify2.flags |= Notification.FLAG_AUTO_CANCEL;
- manager.notify(NOTIFICATION_FLAG, notify2);
- break;
- // 默認通知 API16及之後可用
- case R.id.btn3:
- PendingIntent pendingIntent3 = PendingIntent.getActivity(this, 0,
- new Intent(this, MainActivity.class), 0);
- // 通過Notification.Builder來創建通知,注意API Level
- // API16之後才支持
- Notification notify3 = new Notification.Builder(this)
- .setSmallIcon(R.drawable.message)
- .setTicker("TickerText:" + "您有新短消息,請注意查收!")
- .setContentTitle("Notification Title")
- .setContentText("This is the notification message")
- .setContentIntent(pendingIntent3).setNumber(1).build(); // 需要注意build()是在API
- // level16及之後增加的,API11可以使用getNotificatin()來替代
- notify3.flags |= Notification.FLAG_AUTO_CANCEL; // FLAG_AUTO_CANCEL表明當通知被用戶點擊時,通知將被清除。
- manager.notify(NOTIFICATION_FLAG, notify3);// 步驟4:通過通知管理器來發起通知。如果id不同,則每click,在status哪裏增加一個提示
- break;
- // 自定義通知
- case R.id.btn4:
- // Notification myNotify = new Notification(R.drawable.message,
- // "自定義通知:您有新短信息了,請注意查收!", System.currentTimeMillis());
- Notification myNotify = new Notification();
- myNotify.icon = R.drawable.message;
- myNotify.tickerText = "TickerText:您有新短消息,請注意查收!";
- myNotify.when = System.currentTimeMillis();
- myNotify.flags = Notification.FLAG_NO_CLEAR;// 不能夠自動清除
- RemoteViews rv = new RemoteViews(getPackageName(),
- R.layout.my_notification);
- rv.setTextViewText(R.id.text_content, "hello wrold!");
- myNotify.contentView = rv;
- Intent intent = new Intent(Intent.ACTION_MAIN);
- PendingIntent contentIntent = PendingIntent.getActivity(this, 1,
- intent, 1);
- myNotify.contentIntent = contentIntent;
- manager.notify(NOTIFICATION_FLAG, myNotify);
- break;
- case R.id.btn5:
- // 清除id爲NOTIFICATION_FLAG的通知
- manager.cancel(NOTIFICATION_FLAG);
- // 清除所有的通知
- // manager.cancelAll();
- break;
- default:
- break;
- }
- }
- }
[置頂] Android之Notification使用大全
在3.0以後官方就推薦用建造者模式建Notification
總結了在各種API下Notification的使用情況、關於自定義通知欄的RemoteView的使用可以參考任永剛大神的《Android開發藝術探索》第五章,本人後續也會整理總結,方便日後使用
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.