zoukankan      html  css  js  c++  java
  • Android NotificationManager 和Notification的使用总结 转

     
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    NotificationManager 和Notification的使用总结(转)
    文章分类:移动开发
    这几天一直在修改twigee的源代码,其中一个要加入的功能是常驻Notification栏,以前写的时候只能出现 在“通知”这一组中,想把它放在“正在运行”组中却不知道怎么放,查了下官方文档,找到了方法,在notification的flags字段中加一下 “FLAG_ONGOING_EVENT”就可以了。同时我也把Notification的使用方法给总结了一下。详见下文:
    (1)、使用系统定义的Notification
    以下是使用示例代码:
    //创建一个NotificationManager的引用
    String ns = Context.NOTIFICATION_SERVICE;
    NotificationManager mNotificationManager = (NotificationManager)getSystemService(ns);
    // 定义Notification的各种属性
    int icon = R.drawable.icon; //通知图标
    CharSequence tickerText = "Hello"; //状态栏显示的通知文本提示
    long when = System.currentTimeMillis(); //通知产生的时间,会在通知信息里显示
    //用上面的属性初始化 Nofification
    Notification notification = new Notification(icon,tickerText,when);
    /*
    * 添加声音
    * notification.defaults |=Notification.DEFAULT_SOUND;
    * 或者使用以下几种方式
    * notification.sound = Uri.parse("file:///sdcard/notification/ringer.mp3");
    * notification.sound = Uri.withAppendedPath(Audio.Media.INTERNAL_CONTENT_URI, "6");
    * 如果想要让声音持续重复直到用户对通知做出反应,则可以在notification的flags字段增加"FLAG_INSISTENT"
    * 如果notification的defaults字段包括了"DEFAULT_SOUND"属性,则这个属性将覆盖sound字段中定义的声音
    */
    /*
    * 添加振动
    * notification.defaults |= Notification.DEFAULT_VIBRATE;
    * 或者可以定义自己的振动模式:
    * long[] vibrate = {0,100,200,300}; //0毫秒后开始振动,振动100毫秒后停止,再过200毫秒后再次振动300毫秒
    * notification.vibrate = vibrate;
    * long数组可以定义成想要的任何长度
    * 如果notification的defaults字段包括了"DEFAULT_VIBRATE",则这个属性将覆盖vibrate字段中定义的振动
    */
    /*
    * 添加LED灯提醒
    * notification.defaults |= Notification.DEFAULT_LIGHTS;
    * 或者可以自己的LED提醒模式:
    * notification.ledARGB = 0xff00ff00;
    * notification.ledOnMS = 300; //亮的时间
    * notification.ledOffMS = 1000; //灭的时间
    * notification.flags |= Notification.FLAG_SHOW_LIGHTS;
    */
    /*
    * 更多的特征属性
    * notification.flags |= FLAG_AUTO_CANCEL; //在通知栏上点击此通知后自动清除此通知
    * notification.flags |= FLAG_INSISTENT; //重复发出声音,直到用户响应此通知
    * notification.flags |= FLAG_ONGOING_EVENT; //将此通知放到通知栏的"Ongoing"即"正在运行"组中
    * notification.flags |= FLAG_NO_CLEAR; //表明在点击了通知栏中的"清除通知"后,此通知不清除,
    * //经常与FLAG_ONGOING_EVENT一起使用
    * notification.number = 1; //number字段表示此通知代表的当前事件数量,它将覆盖在状态栏图标的顶部
    * //如果要使用此字段,必须从1开始
    * notification.iconLevel = ; //
    */
    //设置通知的事件消息
    Context context = getApplicationContext(); //上下文
    CharSequence contentTitle = "My Notification"; //通知栏标题
    CharSequence contentText = "Hello World!"; //通知栏内容
    Intent notificationIntent = new Intent(this,Main.class); //点击该通知后要跳转的Activity
    PendingIntent contentIntent = PendingIntent.getActivity(this,0,notificationIntent,0);
    notification.setLatestEventInfo(context, contentTitle, contentText, contentIntent);
    //把Notification传递给 NotificationManager
    mNotificationManager.notify(0,notification);
    如果想要更新一个通知,只需要在设置好notification之后,再次调用 setLatestEventInfo(),然后重新发送一次通知即可,即再次调用notify()。
    (2)、使用自定义的 Notification
    要创建一个自定义的Notification,可以使用RemoteViews。要定义自己的扩展消息,首先 要初始化一个RemoteViews对象,然后将它传递给Notification的contentView字段,再把PendingIntent传递给 contentIntent字段。以下示例代码是完整步骤:
    //1、创建一个自 定义的消息布局 view.xml
    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent" android:layout_height="fill_parent">
    <ImageView android:id="@+id/image" android:layout_width="wrap_content"
    android:layout_height="fill_parent" android:layout_marginRight="10dp" />
    <TextView android:id="@+id/text" android:layout_width="wrap_content"
    android:layout_height="fill_parent" android:textColor="#000" />
    </LinearLayout>
    //2、 在程序代码中使用RemoteViews的方法来定义image和text。然后把RemoteViews对象传到contentView字段
    RemoteViews contentView = new RemoteViews(getPackageName(),R.layout.view);
    contentView.setImageViewResource(R.id.image,R.drawable.icon);
    contentView.setTextViewText(R.id.text,”Hello,this message is in a custom expanded view”);
    notification.contentView = contentView;
    //3、 为Notification的contentIntent字段定义一个Intent(注意,使用自定义View不需要 setLatestEventInfo()方法)
    Intent notificationIntent = new Intent(this,Main.class);
    PendingIntent contentIntent = PendingIntent.getActivity(this,0,notificationIntent,0);
    notification.contentIntent = contentIntent;
    //4、发送通知
    mNotificationManager.notify(2,notification);
    // 以下是全部示例代码
    //创建一个 NotificationManager的引用
    String ns = Context.NOTIFICATION_SERVICE;
    NotificationManager mNotificationManager = (NotificationManager)getSystemService(ns);
    // 定义Notification的各种属性
    int icon = R.drawable.icon; //通知图标
    CharSequence tickerText = "Hello"; //状态栏显示的通知文本提示
    long when = System.currentTimeMillis(); //通知产生的时间,会在通知信息里显示
    //用上面的属性初始化 Nofification
    Notification notification = new Notification(icon,tickerText,when);
    RemoteViews contentView = new RemoteViews(getPackageName(),R.layout.view);
    contentView.setImageViewResource(R.id.image, R.drawable.iconempty);
    contentView.setTextViewText(R.id.text, "Hello,this is JC");
    notification.contentView = contentView;
    Intent notificationIntent = new Intent(this,Main.class);
    PendingIntent contentIntent = PendingIntent.getActivity(this,0,notificationIntent,0);
    notification.contentIntent = contentIntent;
    //把Notification传递给NotificationManager
    mNotificationManager.notify(0,notification);
  • 相关阅读:
    洛谷P2221 [HAOI2012]高速公路(线段树+概率期望)
    洛谷P2254 [NOI2005]瑰丽华尔兹(单调队列)
    洛谷P2607 [ZJOI2008]骑士(基环树)
    洛谷P1505 [国家集训队]旅游(树剖+线段树)
    洛谷P3250 [HNOI2016]网络(整体二分+树状数组+树剖)
    洛谷P3833 [SHOI2012]魔法树(树链剖分)
    洛谷P4216 [SCOI2015]情报传递(树剖+主席树)
    Ansible 利用playbook批量部署Nginx
    Ansible实现zabbix服务器agent端批量部署
    时间序列模型:ARIMA
  • 原文地址:https://www.cnblogs.com/tianshiaimi/p/4843790.html
Copyright © 2011-2022 走看看