Android中Notification详解

下面来谈谈notification,这个notification一般用在电话,短信,邮件,闹钟铃声,在手机的状态栏上就会出现一个小图标,提示用户处理这个快讯,这时手从上方滑动状态栏就可以展开并处理这个快讯。发现这个功能特别好用,所以我就根据我的理解来谈谈。摘自帮助文档 : notification类表示一个持久的通知,将提交给用户使用NotificationManager。已添加的Notification.Builder,使其更容易构建通知。notification是一种让你的应用程序在没有开启情况下或在后台运行警示用户。它是看不见的程序组件(Broadcast Receiver,Service和不活跃的Activity)警示用户有需要注意的事件发生的最好途径。

先来区分以下**状态栏和状态条**的区别:
1、状态条就是手机屏幕最上方的一个条形状的区域;
      在状态条有好多信息量:比如usb连接图标,手机信号图标,电池电量图标,时间图标等等;
2、状态栏就是手从状态条滑下来的可以伸缩的view;
      在状态栏中一般有两类(使用FLAG_标记):
      (1)正在进行的程序;
      (2)是通知事件;

 大概来描述创建一个Notification传送的信息有:
1、**一个状态条图标;**
2、**在拉伸的状态栏窗口中显示带有大标题,小标题,图标的信息,并且有处理该点击事件:比如调用该程序的入口类; **

** 3、闪光,LED,或者震动;**


  快速创建一个Notification的步骤简单可以分为以下四步:
  **第一步**:通过getSystemService()方法得到NotificationManager对象;
  **第二步**:对Notification的一些属性进行设置比如:内容,图标,标题,相应notification的动作进行处理等等;
  **第三步**:通过NotificationManager对象的notify()方法来执行一个notification的快讯;
**  第四步**:通过NotificationManager对象的cancel()方法来取消一个notificatioin的快讯;

 下面对Notification类中的一些常量,字段,方法简单介绍一下:
 常量:
    DEFAULT_ALL                  使用所有默认值,比如声音,震动,闪屏等等
    DEFAULT_LIGHTS            使用默认闪光提示
    DEFAULT_SOUNDS         使用默认提示声音
    DEFAULT_VIBRATE         使用默认手机震动 
  【**说明】:加入手机震动,一定要在manifest.xml中加入权限:**

** ****<uses-permission android:name="android.permission.VIBRATE" />**
以上的效果常量可以叠加,即通过
mNotifaction.defaults =DEFAULT_SOUND | DEFAULT_VIBRATE ;
或mNotifaction.defaults |=DEFAULT_SOUND (最好在真机上测试,震动效果模拟器上没有)

    //设置flag位

** FLAG_AUTO_CANCEL** 该通知能被状态栏的清除按钮给清除掉
** FLAG_NO_CLEAR** 该通知能被状态栏的清除按钮给清除掉
FLAG_ONGOING_EVENT 通知放置在正在运行
** FLAG_INSISTENT ** 是否一直进行,比如音乐一直播放,知道用户响应

  常用字段:
       **contentIntent**                  设置PendingIntent对象,点击时发送该Intent
       defaults                             添加默认效果
       flags                                  设置flag位,例如FLAG_NO_CLEAR等
       **icon **                                 设置图标
       sound                                设置声音
       **tickerText**                        显示在状态栏中的文字
      ** when                                **发送此通知的时间戳

Notification.build构造Notification方法介绍: ** **
** ** void setLatestEventInfo(Context context , CharSequencecontentTitle,CharSequence contentText,PendingIntent contentIntent)


** **功能: 显示在拉伸状态栏中的Notification属性,点击后将发送PendingIntent对象
参数: context 上下文环境
contentTitle 状态栏中的大标题
contentText 状态栏中的小标题
contentIntent 点击后将发送PendingIntent对象
说明:要是在Notification中加入图标,在状态栏和状态条中显示图标一定要用这个方法,否则报错!

  最后说一下NotificationManager类的常用方法:
         通过获取系统服务来获取该对象:            
            NotificationManager mNotificationManager = (NotificationManager)getSystemService(Context.NOTIFICATION_SERVICE) ;

** NotificationManager常用方法介绍:**
public void cancelAll() 移除所有通知 (只是针对当前Context下的Notification)
public void cancel(int id) 移除标记为id的通知 (只是针对当前Context下的所有Notification)
public void** **notify(String tag ,int id, Notification notification) 将通知加入状态栏, 标签为tag,标记为id
public void notify(int id, Notification notification) 将通知加入状态栏,,标记为id
下面看一下demo的效果图:

Paste_Image.png
Paste_Image.png
Paste_Image.png
Paste_Image.png

源码奉上:
在NotificationApp工程里面:
一、在com.cn.notification.daming包下面NotificationMainActivity.java中的代码:

    package com.cn.notification.daming;  
  
import android.app.Activity;  
import android.app.Notification;  
import android.app.NotificationManager;  
import android.app.PendingIntent;  
import android.content.Intent;  
import android.content.SharedPreferences;  
import android.media.RingtoneManager;  
import android.net.Uri;  
import android.os.Bundle;  
import android.preference.PreferenceManager;  
import android.view.View;  
import android.view.View.OnClickListener;  
import android.widget.Button;  
  
public class NotificationMainActivity extends Activity implements OnClickListener {  
private Button setNotificationSoundBtn = null;  
    private Button showNotificatioBtn = null;  
    private Button cancelNotificationBtn = null;  
    private Intent mIntent = null;  
    private PendingIntent mPendingIntent = null;  
    private Notification mNotification = null;  
    private NotificationManager mNotificationManager = null;  
      
    private static final int NOTIFICATION_STATE = 1;  
    private static final int RINGTONE_PICKED = 2;  
      
    private Uri notifiSounds = null;  
      
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.main);  
          
        mNotificationManager = (NotificationManager)getSystemService(NOTIFICATION_SERVICE);  
          
        setNotificationSoundBtn = (Button)findViewById(R.id.button0);  
        setNotificationSoundBtn.setOnClickListener(this);  
        showNotificatioBtn = (Button)findViewById(R.id.button1);  
        showNotificatioBtn.setOnClickListener(this);  
        cancelNotificationBtn = (Button)findViewById(R.id.button2);  
        cancelNotificationBtn.setOnClickListener(this);  
          
        mIntent = new Intent(this, ToNotificationActivity.class);  
        mPendingIntent = PendingIntent.getActivity(this, 0, mIntent, 0);  
          
        mNotification = new Notification();  
    }  
  
    public void onClick(View v) {  
        // TODO Auto-generated method stub  
        switch(v.getId()){  
            case R.id.button0:  
                 SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(this);  
                 Intent intent = new Intent(RingtoneManager.ACTION_RINGTONE_PICKER);  
                 // Allow user to pick 'Default'  
                 intent.putExtra(RingtoneManager.EXTRA_RINGTONE_SHOW_DEFAULT, true);  
                 intent.putExtra(RingtoneManager.EXTRA_RINGTONE_DEFAULT_URI, RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION));  
                 // Show only ringtones  
                 intent.putExtra(RingtoneManager.EXTRA_RINGTONE_TYPE, RingtoneManager.TYPE_NOTIFICATION);  
                 // Don't show 'Silent'  
                 intent.putExtra(RingtoneManager.EXTRA_RINGTONE_SHOW_SILENT, false);  
                 String notifi_sound = sharedPreferences.getString("notification_sounds", null);  
                 if(notifi_sound != null){  
                     intent.putExtra(RingtoneManager.EXTRA_RINGTONE_EXISTING_URI, Uri.parse(notifi_sound));  
                 }  
                 // Launch!  
                 startActivityForResult(intent, RINGTONE_PICKED);  
                break;  
            case R.id.button1:  
                mNotification.icon = R.drawable.daming;  
                mNotification.tickerText = "大明ZeroSon Notification";  
                mNotification.sound = notifiSounds;  
                mNotification.defaults = Notification.DEFAULT_VIBRATE | Notification.DEFAULT_LIGHTS;  
                mNotification.flags = Notification.FLAG_INSISTENT ;   
                mNotification.setLatestEventInfo(this, "大明Notification", "This is Daming`s Notification Test!", mPendingIntent);  
                mNotificationManager.notify(NOTIFICATION_STATE, mNotification);  
                break;  
            case R.id.button2:  
                mNotificationManager.cancel(NOTIFICATION_STATE);  
                break;  
            default:break;  
        }  
    }  
      
    @Override  
    protected void onResume() {  
        super.onResume();  
    }  
  
    @Override  
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {  
        SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(this);    
        SharedPreferences.Editor editor = sharedPreferences.edit();    
          
        if (resultCode != RESULT_OK) {  
            return;  
        }  
        switch (requestCode) {  
            case RINGTONE_PICKED: {  
                notifiSounds = data.getParcelableExtra(RingtoneManager.EXTRA_RINGTONE_PICKED_URI);  
                editor.putString("notification_sounds", notifiSounds.toString());    
                editor.commit();    
                break;  
            }  
            default: break;  
        }  
    }  
}  

二、在com.cn.notification.daming包下面ToNotificationActivity.java中的代码:

package com.cn.notification.daming;  
  
import android.app.Activity;  
import android.content.SharedPreferences;  
import android.media.Ringtone;  
import android.media.RingtoneManager;  
import android.net.Uri;  
import android.os.Bundle;  
import android.preference.PreferenceManager;  
import android.widget.TextView;  
  
public class ToNotificationActivity extends Activity{  
  
    private TextView textview = null;  
      
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.main1);  
          
        SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(this);    
              
        textview = (TextView)findViewById(R.id.textview);  
        String notificationsound = sharedPreferences.getString("notification_sounds", null);  
        if(notificationsound == null){  
            textview.setText("默认Notification声音");  
        } else{  
            Ringtone ringtone =  RingtoneManager.getRingtone(ToNotificationActivity.this, Uri.parse(notificationsound));  
            String title = ringtone.getTitle(ToNotificationActivity.this);  
            textview.setText(title);  
        }  
    }  
}  

三、在layout下main.xml布局文件的代码

<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="vertical"  
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent"  
    >  
    <TextView    
        android:layout_width="fill_parent"   
        android:layout_height="wrap_content"   
        android:text="@string/hello"  
        android:gravity="center"  
        android:layout_marginBottom="10dip"  
     />  
     <Button  
        android:id="@+id/button0"  
        android:layout_width="fill_parent"  
        android:layout_height="wrap_content"  
        android:text="设置Notification的sounds"  
        android:layout_marginBottom="10dip"  
     />  
     <Button  
        android:id="@+id/button1"  
        android:layout_width="fill_parent"  
        android:layout_height="wrap_content"  
        android:text="发送Notification"  
        android:layout_marginBottom="10dip"  
     />  
     <Button  
        android:id="@+id/button2"  
        android:layout_width="fill_parent"  
        android:layout_height="wrap_content"  
        android:text="取消Notification"  
        android:layout_marginBottom="10dip"  
     />  
</LinearLayout>  

四、在layout下main1.xml布局文件的代码

<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="vertical"  
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent"  
    >  
    <TextView   
        android:layout_width="fill_parent"   
        android:layout_height="wrap_content"   
        android:gravity="center"  
        android:textSize="10pt"  
        android:text="大明原创"  
        android:layout_marginTop="10dip"  
        android:layout_marginBottom="10dip"  
     />  
    <TextView   
        android:id="@+id/textview"   
        android:layout_width="fill_parent"   
        android:layout_height="wrap_content"   
        android:gravity="center"  
        android:textSize="10pt"  
        android:layout_marginTop="10dip"  
        android:layout_marginBottom="10dip"  
     />  
</LinearLayout>  

五、manifest.xml中的代码:

<?xml version="1.0" encoding="utf-8"?>  
<manifest xmlns:android="http://schemas.android.com/apk/res/android"  
      package="com.cn.notification.daming"  
      android:versionCode="1"  
      android:versionName="1.0">  
    <uses-sdk android:minSdkVersion="8" />  
    <uses-permission android:name="android.permission.VIBRATE" />   
      
    <application android:icon="@drawable/icon" android:label="@string/app_name">  
        <activity android:name=".NotificationMainActivity"  
                  android:label="@string/app_name">  
            <intent-filter>  
                <action android:name="android.intent.action.MAIN" />  
                <category android:name="android.intent.category.LAUNCHER" />  
            </intent-filter>  
        </activity>  
        <activity android:name=".ToNotificationActivity"></activity>  
    </application>  
</manifest>  
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容