我们在用手机的时候,如果来了短信,而我们没有点击查看的话,是不是在手机的最上边的状态栏里有一个短信的小图标提示啊?你是不是也想实现这种功能呢?今天的notification就是解决这个问题的。
我们也知道android系统也是在不断升级的,有关notification的用法也就有很多种,有的方法已经被android抛弃了,现在我实现了三种不同的方法,并适应不同的android版本。现在我就把代码公布出来,我喜欢把解释写在代码中,在这里我就不多说了,先看效果图:
再看代码,主要的代码如下:
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
104
105
106
107
|
package net.loonggg.notification; 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 ; } } } |
再看主布局文件:
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
|
<linearlayout 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" android:orientation= "vertical" tools:context= ".mainactivity" > <button android:id= "@+id/btn1" android:layout_width= "fill_parent" android:layout_height= "wrap_content" android:onclick= "notificationmethod" android:text= "默认通知(已被抛弃,但是通用)" /> <button android:id= "@+id/btn2" android:layout_width= "fill_parent" android:layout_height= "wrap_content" android:onclick= "notificationmethod" android:text= "默认通知(api11之后可用)" /> <button android:id= "@+id/btn3" android:layout_width= "fill_parent" android:layout_height= "wrap_content" android:onclick= "notificationmethod" android:text= "默认通知(api16之后可用)" /> <button android:id= "@+id/btn4" android:layout_width= "fill_parent" android:layout_height= "wrap_content" android:onclick= "notificationmethod" android:text= "自定义通知" /> <button android:id= "@+id/btn5" android:layout_width= "fill_parent" android:layout_height= "wrap_content" android:onclick= "notificationmethod" android:text= "清除通知" /> </linearlayout> |
还有一个是:自定义通知的布局文件my_notification.xml,代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
|
<?xml version= "1.0" encoding= "utf-8" ?> <linearlayout xmlns:android= "http://schemas.android.com/apk/res/android" android:layout_width= "match_parent" android:layout_height= "wrap_content" android:background= "#ffffff" android:orientation= "vertical" > <textview android:id= "@+id/text_content" android:layout_width= "wrap_content" android:layout_height= "wrap_content" android:textsize= "20sp" /> </linearlayout> |
如何使自己的notification像android qq一样能出现在 “正在运行的”栏目下面
其实很简单,只需设置notification.flags = notification.flag_ongoing_event;便可以了。
如何改变 notification 在“正在运行的”栏目下面的布局
创建 remoteviews 并赋给 notification.contentview ,再把 pendingintent 赋给 notification.contentintent 便可以了,如:
1
2
3
4
5
6
7
8
9
10
11
|
pendingintent contentintent = pendingintent.getactivity( arg0.getcontext(), r.string.app_name, i, pendingintent.flag_update_current); remoteviews rv = new remoteviews(main. this .getpackagename(), r.layout.notification_view); rv.setimageviewresource(r.id.image, r.drawable.chat); rv.settextviewtext(r.id.text, "hello,there,i'm john." ); n.contentview = rv; n.contentintent = contentintent; nm.notify(r.string.app_name, n); |
注意,如果使用了contentview,那么便不要使用notification.setlatesteventinfo。如果setlatesteventinfo在赋给 notification.contentview 的代码之后,那么contentview的效果将被覆盖,显示的便是 setlatesteventinfo 的效果;如果 setlatesteventinfo 在 notification.contentview 的代码之前,那么显示的便是 notification.contentview 的效果,也就是说不管你想要setlatesteventinfo 或 contentview 的自定义效果,请保证始终只有一句设置代码,因为在最后一句绑定的时候,之前的设置contentview或setlatesteventinfo的代码都是完全没有必要的。