本文同步個人 CSDN 博客
轉載請註明出處
blog.csdn.net/wufeng55/ar…javascript
建立併發送一個系統通知php
activity_main.xmljava
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.example.mu_16jj.notificationdemo.MainActivity">
<TextView android:id="@+id/tv_send_notification" android:layout_width="wrap_content" android:layout_height="35dp" android:layout_centerInParent="true" android:gravity="center" android:background="@color/colorAccent" android:text="send notification" android:textSize="16sp" />
</RelativeLayout>複製代碼
很簡單的佈局,就一個 TextView 利用其點擊事件來發送通知。android
建立 Notification併發
private void createNotification() {
notification = new NotificationCompat.Builder(MainActivity.this)
.setContentTitle("Notification title")
.setTicker("Ticker method function...")
.setContentText("Notification content text")
.setSubText("subtext...")
.setWhen(System.currentTimeMillis())
.setSmallIcon(R.mipmap.ic_launcher_round)
.setLargeIcon(BitmapFactory.decodeResource(getResources(), R.drawable.large_icon))
.build();
}複製代碼
經過 NotificationCompat.Build 來構建一個 Notification 對象,並設置一系列屬性(每一個屬性對應的效果後面展現)。ide
發送按鈕監聽佈局
notificationManager.notify(1, notification);複製代碼
這裏須要說明的是,Notification 的發送仍是由 NotificationManager 來管理的,第一個參數用來標識一個惟一的 Notification;第二個參數就是須要發送的 Notification 對象。咱們在 onCreate 方法中經過如下代碼初始化了通知管理器對象:學習
notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);複製代碼
運行效果ui
建立通知時的一些基本屬性就利用效果圖解釋完了,其中的 setTicker 須要真機運行才能夠看到效果。
但是,這個時候咱們點擊這條通知後,該通知一直在系統狀態欄,既沒有消失,也沒有頁面跳轉,這並非咱們想要的效果,因此下面就來實現點擊通知跳轉頁面,這裏以系統提供的登陸 Activity 爲目的界面。this
修改咱們建立通知的方法
private void createNotification() {
Intent intent = new Intent(this, LoginActivity.class);
PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, intent, 0);
notification = new NotificationCompat.Builder(MainActivity.this)
.setContentTitle("Notification title")
.setContentText("Notification content text")
.setSubText("subtext...")
.setWhen(System.currentTimeMillis())
.setSmallIcon(R.mipmap.ic_launcher_round)
.setLargeIcon(BitmapFactory.decodeResource(getResources(), R.drawable.large_icon))
.setContentIntent(pendingIntent)
.setAutoCancel(true)
.build();
}複製代碼
能夠看到,這裏增長了一個 setContentIntent 方法,該方法接收一個 PendingIntent 參數,而獲取該實例則能夠有三種途徑:getActivity(),getBroadcast(),getService();這幾個方法所接收的參數都是相同的,第一個是上下文,第二個參數通常不多使用,傳 0 便可,第三個參數即是點擊通知須要跳轉的 Intent 意圖對象(LoginActivity直接使用 AS 提供的模板),第四個參數用於肯定 PendingIntent 的行爲,有 4 種植可選:FLAG_ONE_SHOT,FLAG_NO_CREATE,CANCEL_CURRENT 和 FLAG_UPDATE_CURRENT。
運行效果
主要常量
FLAG_CANCEL_CURRENT:若是當前系統中已經存在一個相同的 PendingIntent 對象,那麼就將先前已有的 PendingIntent 取消,而後從新生成一個 PendingIntent 對象。
FLAG_NO_CREATE:若是當前系統中不存在相同的 PendingIntent 對象,系統將不會建立該 PendingIntent 對象而是直接返回 null。
FLAG_ONE_SHOT:該 PendingIntent 只做用一次。在該 PendingIntent 對象經過send() 方法觸發事後,PendingIntent 將自動調用 cancel() 進行銷燬,那麼若是你再調用 send() 方法的話,系統將會返回一個 SendIntentException。
FLAG_UPDATE_CURRENT:若是系統中有一個和你描述的 PendingIntent 對等的PendingInent,那麼系統將使用該 PendingIntent 對象,可是會使用新的 Intent 來更新以前 PendingIntent 中的 Intent 對象數據,例如更新 Intent 中的 Extras。
PendingIntent 和 Intent
PendingIntent 是一個特殊的 Intent,主要區別是 intent 是立馬執行,PendingIntent 是待肯定的 Intent。PendingIntent 的操做其實是傳入的 intent 的操做。使用 pendingIntent 的目的主要是用於所包含的 intent 執行是否知足某些條件。
有兩種辦法,一種是給 Notification 設置
setAutoCancel(true)複製代碼
另外一種是經過通知管理器調用 cancel 方法,該方法有一個參數,就是咱們前面發送的時候設置的惟一標識。
通知,設置特效
咱們常見的手機 APP 當有推送消息或者電話之類的通知時,咱們的手機 LED 燈會亮起來,並且顏色也會不同,有時候還會有聲音,或者震動之類的,下面就來學習這些方法,這裏我經過監聽手機鎖屏的廣播來發送通知(效果會更好),再也不使用上面的按鈕來發送(鎖屏速度快的話效果仍是能夠看到的)。
建立通知代碼
private void createNotification() {
Intent intent = new Intent(this, LoginActivity.class);
PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, intent, 0);
notification = new NotificationCompat.Builder(MainActivity.this)
.setContentTitle("Notification title")
.setContentText("Notification content text")
.setSubText("subtext...")
.setWhen(System.currentTimeMillis())
.setSmallIcon(R.mipmap.ic_launcher_round)
.setLargeIcon(BitmapFactory.decodeResource(getResources(), R.drawable.large_icon))
// 跳轉界面 系統狀態欄通知消失
.setContentIntent(pendingIntent)
.setAutoCancel(true)
// 收到通知時播放聲音並震動
.setDefaults(NotificationCompat.DEFAULT_SOUND) // 默認通知聲音
// .setSound(Uri.fromFile(new File("/system/media/audio/ringtones/Luna.ogg")))
.setVibrate(new long[]{0, 1000, 1000, 1000})
// LED 燈顏色
.setLights(Color.RED, 1000, 1000)
// 根據手機的當前環境使用默認
// .setDefaults(NotificationCompat.DEFAULT_ALL)
.build();
}複製代碼
這裏的註釋已經很清楚了,須要注意的是震動是須要權限的:
<uses-permission android:name="android.permission.VIBRATE" />複製代碼
廣播接收器
/** * 監聽手機鎖屏 */
public class MyReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
if (intent.getAction().equals(Intent.ACTION_SCREEN_OFF)) {
notificationManager.notify(1, notification);
}
}
}複製代碼
關注註冊廣播問題,請看《Android 廣播介紹以及使用示例》
高級之 setStyle() 和 setPriority() 方法
通知內容支持長文本
.setStyle(new NotificationCompat.BigTextStyle().bigText("The failures and reverses which await men - and one after another sadden the brow of youth - add a dignity to the prospect of human life, which no Arcadian success would do. -- Henry David Thoreau"))複製代碼
運行效果
.setStyle(new NotificationCompat.BigPictureStyle().bigPicture(BitmapFactory.decodeResource(getResources(), R.drawable.large_icon)))複製代碼
運行效果.setPriority(NotificationCompat.PRIORITY_MAX)複製代碼
運行效果(PRIORITY_MAX)
自定義佈局通知
咱們在已有的界面基礎上再增長一個 TextView 用它的點擊事件來發送自定義通知,自定義通知代碼以下:
/** * 建立自定義佈局通知 */
private void createCustomNotification() {
RemoteViews remoteViews = new RemoteViews(getPackageName(), R.layout.custom_notification_layout);
remoteViews.setImageViewResource(R.id.iv_cus_notification, R.mipmap.ic_launcher);
remoteViews.setTextViewText(R.id.tv_cus_notification, "Notification of Android");
remoteViews.setTextViewText(R.id.btn_cus_notification, "Button");
cusNotification = new NotificationCompat.Builder(MainActivity.this)
// 切記,必定要設置,不然通知顯示不出來
.setSmallIcon(R.mipmap.ic_launcher)
.setContent(remoteViews)
.setTicker("Custom Notification")
.setAutoCancel(true)
.setDefaults(NotificationCompat.DEFAULT_ALL)
.build();
}複製代碼
能夠看到,相比系統通知的建立,這裏多了一個新的 API——RemoteViews. 咱們的自定義佈局就是經過它來加載,經過它的一系列 setXXX 方法能夠給咱們的佈局中控件設置相關屬性,而後經過 Builder 的 setContent 方法將其設置上去,這樣咱們的自定義通知效果就實現了。
點擊事件
notificationManager.notify(2, cusNotification);複製代碼
運行效果
關於通知的自定義佈局從效果就能夠看到,很簡單,這裏不貼出。
注意點
自定義通知佈局的可用高度取決於通知視圖。普通視圖佈局限制爲 64 dp,擴展視圖佈局限制爲 256 dp。
不管是系統通知仍是自定義佈局通知,smallIcon 是必須設置的。