Notification(狀態列通知)詳解


本節引言:

本節帶來的是Android中用來在狀態列顯示通知訊息的控制項:Notification,相信大部分 學Android都對他都很熟悉,而網路上很多關於Notification的使用教程都是基於2.x的,而 現在普遍的Android設備基本上都在4.x以上,甚至是5.0以上的都有;他們各自的Notification 都是不一樣的!而本節跟大家講解的是基於4.x以上的Notification,而5.0以上的Notification 我們會在進階教學的Android 5.0新特性的章節進行解說~

官方文件對Notification的一些介紹:

設計想法:Notifications in Android 4.4 and Lower

翻譯:通知

API文件:Notification

訪問上述網站,可能需要梯子哦~


1.設計文件部分解讀


1)Notification的基本佈局

1.png

上面的組成元素依序是:

  • Icon/Photo:大圖示
  • Title/Name:標題
  • ##Message:內容資訊
  • Timestamp:通知時間,預設是系統發出通知的時間,也可以透過setWhen()來設定
  • Secondary Icon:小圖示
  • 內容文字,在小圖示的左手邊的一個文字

2)擴充佈局

在Jelly Bean 中你可以為通知提供更多事件的細節。你可以透過擴展佈局顯示訊息的前幾行或是圖片的預覽。這樣用戶可以看多更多的內容 - 有時甚至可以看到整個訊息。使用者可以透過 pinch-zoom 或雙手指滑動來打開擴展佈局。 Android 為單一訊息提供了兩種擴充佈局 (文字和圖像) 供你開發應用程式時使用。

2.png

3.png

關於其他一些設計的東西,就不一一提及了,有興趣的自行查看上面提供的API文檔,知道下 這個Notification在4.x以上的版本可以多樣就好!我們更多的時候關注的是 如何寫程式使用這個東西,下面我們就來學習下Notification的用法!


2.Notification的基本使用流程

狀態通知列主要涉及到2個類別:Notification 和NotificationManager

Notification:通知資訊類,它裡面​​對應了通知欄的各個屬性

NotificationManager:是狀態列通知的管理類,負責發通知、清除通知等操作。

使用的基本流程:

  • Step 1. 取得NotificationManager物件: NotificationManager mNManager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
  • Step 2. 建立一個通知欄的Builder建構類別: Notification.Builder mBuilder = new Notification.Builder(this);
  • Step 3. 對Builder進行相關的設置,例如標題,內容,圖標,動作等!
  • Step 4.呼叫Builder的build()方法為notification賦值
  • Step 5.呼叫NotificationManager的notify()方法傳送通知!
  • PS:另外我們也可以呼叫NotificationManager的cancel()方法取消通知

3.設定相關的一些方法:

Notification.Builder mBuilder = new Notification.Builder(this);

後再呼叫下述的相關的方法進行設定:(官方API文件:Notification.Builder) 常用的方法如下:

  • setContentTitle(CharSequence):設定標題
  • setContentText(CharSequence):設定內容
  • #setSubText(CharSequence):設定內容下面一小行的文字
  • setTicker(CharSequence):設定收到通知時在頂部顯示的文字訊息
  • setWhen(long):設定通知時間,一般設定的是收到通知時的System.currentTimeMillis()
  • setSmallIcon(int):設定右下角的小圖標,在接收到通知的時候頂部也會顯示這個小圖示
  • setLargeIcon(Bitmap):設定左邊的大圖示
  • setAutoCancel#(boolean ):使用者點選Notification點擊面板後是否讓通知取消(預設不取消)
  • setDefaults(int):為通知新增聲音、閃光燈和振動效果的最簡單、 使用預設(defaults)屬性,可以組合多個屬性,
    Notification.DEFAULT_VIBRATE(新增預設震動提醒);
    Notification.DEFAULT_SOUND(新增預設聲音提醒) ;
    Notification.DEFAULT_LIGHTS(新增預設三色燈提醒)
    Notification.DEFAULT_ALL(新增預設以上3種全部提醒)
  • #setVibrate(long[]):設定振動方式,例如:
    setVibrate(new long[] {0,300,500,700});延遲0ms,然後振動300ms,在延遲500ms, 接著再振動700ms,關於Vibrate用法後面會講解!
  • setLights(int argb, int onMs, int offMs):設定三色燈,參數依序為:燈光顏色, 亮持續時間,暗的時間,不是所有顏色都可以,這跟設備有關,有些手機還不帶三色燈; 另外,還需要為Notification設定flags為Notification.FLAG_SHOW_LIGHTS才支援三色燈提醒!
  • setSound(Uri):設定接收到通知時的鈴聲,可以用系統的,也可以自己設置,範例如下:
    .setDefaults(Notification.DEFAULT_SOUND )  //取得預設鈴聲
    .setSound(Uri.parse("file:///sdcard/xx/xx.mp3"))  //取得自訂鈴聲
    .setSound(Uri.withAppendedPath(Audio. Media.INTERNAL_CONTENT_URI, "5")) //取得Android多媒體函式庫內的鈴聲

  • setOngoing(boolean):設定為ture,表示它為一個正在進行的通知。他們通常是用來表示 一個後台任務,用戶積極參與(如播放音樂)或以某種方式正在等待,因此佔用設備(如一個文件下載, 同步操作,主動網路連線)

  • setProgress(int,int,boolean):設定帶進度條的通知 參數依序為:進度條最大數值,當前進度,進度是否不確定 如果為確定的進度條:呼叫setProgress(max, progress, false)來設定通知, 在更新進度的時候在此發起通知更新progress,並且在下載完成後要移除進度條 ,透過呼叫setProgress(0, 0, false)既可。如果為不確定(持續活動)的進度條, 這是在處理進度無法準確獲知時顯示活動正在持續,所以呼叫setProgress(0, 0, true) ,操作結束時,呼叫setProgress(0, 0, false)並更新通知以移除指示條
  • setContentIntent(PendingIntent):PendingIntent和Intent略有不同,它可以設定執行次數, 主要用於遠端服務通訊、鬧鈴、通知、啟動器、簡訊中,在一般情況下使用的比較少。例如這裡透過 Pending啟動Activity:getActivity(Context, int, Intent, int),當然還可以啟動Service或Broadcast PendingIntent的位元識別碼(第四個參數):
    FLAG_ONE_SHOT   表示傳回的PendingIntent只能執行一次,執行完後自動取消
    FLAG_NO_CREATE  表示如果描述的PendingIntent不存在,並不會建立對應的PendingIntent,而是傳回NULL
    FLAG_CANCEL_CURRENT 表示對應的PendingIntent已經存在,則取消前者,然後建立新的PendingIntent, 這個有利於資料保持為最新的,可以用於即時通訊的通訊場景
    FLAG_UPDATE_CURRENT 表示更新的PendingIntent
    使用範例:

    //点击后跳转Activity
    Intent intent = new Intent(context,XXX.class);  
    PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, intent, 0);  
    mBuilder.setContentIntent(pendingIntent)


  • setPriority(int):設定優先權:

    ##優先權使用者MAX重要且緊急的通知,通知使用者這個事件是時間上緊迫的或需要立即處理的。 HIGH高優先權用於重要的通訊內容,例如短訊息或聊天,這些都是對使用者來說比較有興趣的。 DEFAULT預設優先權用於沒有特殊優先權分類的通知。 LOW低優先順序可以通知使用者但又不是很緊急的事件。 MIN用於後台訊息 (例如天氣或位置資訊)。最低優先級通知將只在狀態列中顯示圖標,只有用戶下拉通知抽屜才能看到內容。 對應屬性:Notification.PRIORITY_HIGH...

    4.程式碼範例:最常見的Notification:

    下面我們來寫一個最簡單的範例來體驗下Notification的用法:

    執行效果圖

    4.gif

    關鍵程式碼

    這裡直接貼MainActivity.java的程式碼:

    公共類別MainActivity擴充AppCompatActivity實作View.OnClickListener{

    #    私有Context mContext;
         私有NotificationManager mN c  # #    private static final int NOTIFYID_1 = 1;

        private Button btn_show_normal;# 
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);# ࠠ). //建立大圖示的Bitmap
            LargeBitmap = BitmapFactory.decodeResource(getResources (getResources(getResources(getResources)) ), R.mipmap.iv_lc_icon);
            mNManager = (NotificationManager  }


        private void bindView() {
            btn_show_normal = (Button) findViewById(R.id findViewById(R.id.btn_close_normal);
            btn_show_normal.setOnClickListener( this);
            btn_close_normal。 switch (v.getId()) {
                case R.id .btn_show_normal:
                    Inte = new Intent(mContext, OtherActivity.class);
                    PendingIntent pit        PendingIntent pit (mContext,0,它,0 );

                    //設定圖片,通知標題,傳送時間、提示方式等屬性
                           mBuilder.setContentTitle("葉良辰")                 ##                        .setContentText("我有一百種方法讓你呆       .setSubText("-記得我叫葉良辰")                    //內容下方的一小段文字

    1 #                        .setTicker("收到葉良辰寄來的資訊~")                     .setWhen(System.currentTimeMillis())              .setSmallIcon (R.mipmap.ic_lol_icon)            //設定小圖示
                             //設定大圖示
                       //設定預設的三色燈與振動器
    .setSound(Uri.parse("android.resource://" + getPackageName() + "/" + R.raw.biaobiao))  //設定自訂的提示音
       oCancel(true)                           //設定點選後取消Notification
                            .setContentIntent(pit);   ingIntent
                    notify1 = mBuilder.build();
             _c              break;

                case R.id.btn_close_normal:
                           mNManager.cancel(NOTIFYID_1);                    
                    break;

            }
        }
    }

    註釋很詳細,就不一一細講了~

    5.程式碼範例下載:

    NotificationDemo.zip

    本節小結:

    好的,本節介紹了Notification在4. x版的基本用法,非常簡單是吧~
    當然你也可以自訂Notification有興趣的可以自己查閱相關資料,這裡就不慢慢 研究了~對了,本節部分內容參考的下述blog,貼下鏈接,大家也可以去看下:Android 通知欄Notification的整合全面學習(一個DEMO讓你完全了解它)寫得蠻詳細的~本節就到這裡,謝謝~


    #