- 浏览: 86978 次
- 性别:
- 来自: 长沙
文章分类
最新评论
-
wangyudong:
家里是拨号上网,不行的,找到了一个Holer工具,只需要配置一 ...
【如何通过广域网访问局域网的服务器?】 -
叮咚可乐名:
大数据就是这么任性第一季数据结构和算法http://pan.b ...
数据结构与算法-简介 -
戢_时光:
...
【Java集合之二】Set集合 -
lzg406:
HTTP默认方式下,使用持久连接。 这个值得推敲
【应用层】之一:HTTP协议与FTP协议 -
mute_:
特别腻害呢
正则表达式1:概念
本文围绕以下两个部分展开:
一、通知
案例一
一、通知
1. 概念:
Notification提醒用户,这些提醒可以通过很多途经去引起用户的注意,如闪烁背景灯、设备震动、播放背景音乐等等。 一个典型的方法是在状态栏上放一个图标,用户可以打开它获取信息。
Notification是一些不可见组件(Broadcast Receivers、Services)通知用户的优先选择。
2. Notification与Toast的区别
Notification与Toast都可以起到通知、提醒的作用,但它们的实现原理和表现形式完全不一样。
(1)Toast其实相当于一个组件(Widget),有些类似于没有按钮的对话框。而Notification是显示在屏幕上方状态栏中的信息。
(2)Notification需要用NotificationManager来管理,而Toast只需要简单地创建Toast对象即可。
3. PendingIntent(挂起Intent)和Intent区别
Intent通常用于马上处理的事情,PendingIntent通常使用于未来处理的事情,常常用于Notification和AlarmManager。PendingIntent就是一个Intent的描述,我们可以把这个描述交给别的程序,别的程序根据这个描述在后面的别的时间做你安排做的事情。
由于 Notification可以与应用程序脱离。也就是说,即使应用程序关闭,Notification仍然会显示在状态栏中。当应用程序启动后,又可以重新控制这些 Notification,如清除或替换它们。因此需要创建一个 PendingIntent对象。该对象由Android负责维护,因此,在应用程序关闭后,该对象仍然不会被释放。【比如,某个 app弹出通知,当app关掉后,通知还显示在通知栏中。】
Intent通常用于马上处理的事情,PendingIntent通常使用于未来处理的事情,常常用于Notification和AlarmManager。PendingIntent就是一个Intent的描述,我们可以把这个描述交给别的程序,别的程序根据这个描述在后面的别的时间做你安排做的事情。
案例一
1. 创建一个 IntentService:NotificationService。
2. activity_main.xml。写一个按钮。
3. MainActivity。按钮点击事件。
4. NotificationService。写通知服务。
5. MainActivity。当点击通知,重新回到活动界面(此时会调用 onStart 方法)后,通知就取消掉了。
代码补充:
MainActivity。
一、通知
案例一
一、通知
1. 概念:
Notification提醒用户,这些提醒可以通过很多途经去引起用户的注意,如闪烁背景灯、设备震动、播放背景音乐等等。 一个典型的方法是在状态栏上放一个图标,用户可以打开它获取信息。
Notification是一些不可见组件(Broadcast Receivers、Services)通知用户的优先选择。
2. Notification与Toast的区别
Notification与Toast都可以起到通知、提醒的作用,但它们的实现原理和表现形式完全不一样。
(1)Toast其实相当于一个组件(Widget),有些类似于没有按钮的对话框。而Notification是显示在屏幕上方状态栏中的信息。
(2)Notification需要用NotificationManager来管理,而Toast只需要简单地创建Toast对象即可。
3. PendingIntent(挂起Intent)和Intent区别
Intent通常用于马上处理的事情,PendingIntent通常使用于未来处理的事情,常常用于Notification和AlarmManager。PendingIntent就是一个Intent的描述,我们可以把这个描述交给别的程序,别的程序根据这个描述在后面的别的时间做你安排做的事情。
由于 Notification可以与应用程序脱离。也就是说,即使应用程序关闭,Notification仍然会显示在状态栏中。当应用程序启动后,又可以重新控制这些 Notification,如清除或替换它们。因此需要创建一个 PendingIntent对象。该对象由Android负责维护,因此,在应用程序关闭后,该对象仍然不会被释放。【比如,某个 app弹出通知,当app关掉后,通知还显示在通知栏中。】
Intent通常用于马上处理的事情,PendingIntent通常使用于未来处理的事情,常常用于Notification和AlarmManager。PendingIntent就是一个Intent的描述,我们可以把这个描述交给别的程序,别的程序根据这个描述在后面的别的时间做你安排做的事情。
案例一
1. 创建一个 IntentService:NotificationService。
package com.android.notification; import android.app.IntentService; import android.content.Intent; public class NotificationService extends IntentService { public NotificationService() { super("NotificationService"); } @Override protected void onHandleIntent(Intent intent) { } }
2. activity_main.xml。写一个按钮。
<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" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".MainActivity"> <Button android:id="@+id/btnDownload" android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="download" android:text="下载" /> </RelativeLayout>
3. MainActivity。按钮点击事件。
/** * 按钮点击事件 * * @param view */ public void download(View view) { // 下载的时候,启动通知服务 startService(new Intent(this, NotificationService.class)); }
4. NotificationService。写通知服务。
package com.android.notification; import android.app.IntentService; import android.app.Notification; import android.app.NotificationManager; import android.app.PendingIntent; import android.content.Intent; import android.support.v4.app.NotificationCompat; import android.util.Log; public class NotificationService extends IntentService { private static final String TAG = "NotificationService"; public NotificationService() { super("StatusService"); } @Override protected void onHandleIntent(Intent intent) { Log.i(TAG, "开始下载..."); // 1. 设置正在下载(false) showNotification(false); // 2. 下载 try { // 模拟下载 - 10秒 Thread.sleep(10000); // 通知:下载完成 showNotification(true); } catch (InterruptedException e) { e.printStackTrace(); } Log.i(TAG, "下载完成..."); } /** * 3. 显示通知 * * @param finish 下载完成为 true */ private void showNotification(boolean finish) { // 4. 创建通知管理器(通知管理的服务) NotificationManager nm = (NotificationManager) getSystemService(NOTIFICATION_SERVICE); // 5. /* NotificationCompat.Builder : Builder class for NotificationCompat objects. Allows easier control over all the flags, as well as help constructing the typical notification layouts. */ NotificationCompat.Builder builder = null; // 6. 设置跳转到某个活动的意图 (此程序中,是回到主界面) Intent intent = new Intent(this, MainActivity.class); // 7. PendingIntent contentIntent = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT); // 8. 更新通知中的文字 // 如果下载未完成(开始下载) if (!finish) { builder = new NotificationCompat.Builder(this) .setSmallIcon(R.drawable.sym_call_missed) .setContentTitle("开始下载") .setContentText("正在下载中") .setContentIntent(contentIntent); } else { builder = new NotificationCompat.Builder(this) .setSmallIcon(R.drawable.sym_call_missed) .setContentTitle("下载完成") .setContentText("下载完成") .setContentIntent(contentIntent); } // 9. 建造 通知 Notification notification = builder.build(); // 10. 通知声音/震动/LED闪光 notification.defaults = Notification.DEFAULT_ALL; // 11. 当点击 “下载” 按钮的时候,通知管理器 唤醒通知 nm.notify(R.id.btnDownload, notification); } }
5. MainActivity。当点击通知,重新回到活动界面(此时会调用 onStart 方法)后,通知就取消掉了。
/** * 当点击通知,重新回到活动界面(此时会调用 onStart 方法)后,通知就取消掉了。 */ @Override protected void onStart() { super.onStart(); // 16.1 创建通知管理器(通知管理的服务) NotificationManager nm = (NotificationManager) getSystemService(NOTIFICATION_SERVICE); // 16.2 通知管理器 取消通知 // 注意:取消通知的 id 和 15.中 通知的 id 要一致 nm.cancel(R.id.btnDownload); }
代码补充:
MainActivity。
package com.android.notification; import android.app.Activity; import android.app.NotificationManager; import android.content.Intent; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; import android.view.View; public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } /** * 按钮点击事件 * * @param view */ public void download(View view) { // 下载的时候,启动通知服务 startService(new Intent(this, NotificationService.class)); } /** * 当点击通知,重新回到活动界面(此时会调用 onStart 方法)后,通知就取消掉了。 */ @Override protected void onStart() { super.onStart(); // 16.1 创建通知管理器(通知管理的服务) NotificationManager nm = (NotificationManager) getSystemService(NOTIFICATION_SERVICE); // 16.2 通知管理器 取消通知 // 注意:取消通知的 id 和 15.中 通知的 id 要一致 nm.cancel(R.id.btnDownload); } }
发表评论
-
【攻克Android (43)】WebView (网络视图)
2015-09-09 22:15 1198本文围绕以下两个部分展开: 一、WebView WebVi ... -
WebView (网络视图)
2015-09-09 22:12 0本文围绕以下两个部分展开: 一、WebView WebVi ... -
【攻克Android (41)】HttpURLConnection
2015-09-08 17:43 1298本文围绕以下三个部分展开: 一、HttpURLConnec ... -
HttpURLConnection
2015-09-08 17:42 0本文围绕以下三个部分展开: 一、HttpURLConnec ... -
【攻克Android (40)】JSON解析
2015-09-07 20:49 1225本文围绕以下三个部分 ... -
JSON解析
2015-09-07 20:47 0本文围绕以下三个部分 ... -
【攻克Android (39):XML解析之四】Simple方式解析XML
2015-08-27 18:38 1653本文围绕以下三个部分 ... -
【攻克Android (38):XML解析之三】Pull方式解析XML
2015-08-27 09:25 1682本文围绕以下两个部分展开: 一、Pull解析 案例一:P ... -
【攻克Android (37):XML解析之二】SAX方式解析XML
2015-08-26 15:15 836本文围绕以下两个部分展开: 一、SAX解析 案例一 ... -
【XML解析之一】SAX方式解析XML
2015-08-26 02:58 0本文围绕以下四个部分展开: 一、SAX解析 案例一 ... -
【攻克Android (36):XML解析之一】DOM方式解析XML
2015-08-26 00:27 881本文围绕以下三个部分展开: 一、XML概述 二、DOM解析 ... -
DOM方式解析XML案例
2015-08-26 00:26 0本文围绕以下四个部分展开: 一、DOM解析 案例一 ... -
【XML解析之四】Simple方式解析XML
2015-08-27 18:36 0本文围绕以下三个部分 ... -
【XML解析之一】Pull方式解析XML
2015-08-26 02:56 0本文围绕以下四个部分展开: 一、Pull解析 案例一:P ... -
【攻克Android (22)】View/Tween Animation 视图动画(补间动画)
2015-08-25 21:22 830本文围绕以下四个部分 ... -
【攻克Android (22)】View/Tween Animation 视图动画(补间动画)
2015-08-25 21:21 0本文围绕以下四个部分 ... -
【攻克Android (45)】四大组件之 ContentProvider
2015-08-18 16:24 994本文围绕以下两个部分展开: 一、ContentProvide ... -
Notification 通知
2015-08-17 19:56 0本文围绕以下两个部分展开: 一、通知 案例一 一 ... -
BroadcastReceiver完整版
2015-08-17 13:15 0本文围绕以下四个部分展开: 一、广播 案例一:系统广播(属于 ... -
【攻克Android (33)】四大组件之 BroadcastReceiver
2015-08-17 13:14 1059本文围绕以下三个部分 ...
相关推荐
Android实现Notification的通知栏常驻.zip
修改android 2.3版本Notification通知栏不显示的Bug Android 服务端下载 Notification通知栏 断点下载
使用android push notification service 实现即时通知
NULL 博文链接:https://Adam289.iteye.com/blog/1879852
Android 通知(notification)简单实用Demo,包含点击功能简单例子,供大家下载学习
Android Notification通知 简单使用 demo下载。 解决问题:兼容高低版本,帮助用户打开通知开关,android5.x手机状态栏icon是白块问题。 详细文章请参考 ...
这几天做一个小软件在API28(Android 9.0)的模拟器上测试时,发现通知栏无效,经过一番查询,了解到:API26(Android 8.0)以后,引入了**通知渠道(Notification Channels)**这么一个东西来帮助用户管理通知。...
android 利用notification 通知栏 实现动态下载.
主要利用了notification service 和receiver 实现了用户通知栏更新,失败了点击重新下载,下载好了点击自动安装,布局很丑,请根据自己项目的实际需求自行修改
notification是一种出现在任务栏的提示,特别是在4.0以后notification改进了不少,本文内容都是基于4.0及4.1以后总结来的,详细介绍各种布局的Notification样式,实现音乐播放器、邮件通知等复杂的例子详细代码。
Android 使用Notification自定义通知栏显示。自定义系统状态栏通知类NotificationExtend,也可以手动更新状态栏。依据此项目可以做成线程接受,或者广播接受自动更新。我博客网址: ...
android notification 通知 源码 例子
Android自定义Notification,很实用的一个功能
android 8.0 对 通知栏有了很大的改变,以往的方法写通知栏会报错,google新加了一个notificationChannel,而且必须添加,这里是Demo。
Android push notification(即androidpn) 服务端源代码 非bin文件,而是源代码!
Android高级应用源码-状态栏通知小图标,notification通知.zip
android消息通知栏Notification
notification在新版本的SDK上的写法 blog:http://www.cnblogs.com/ityizhainan/p/6282031.html
Android-Notification-Example-master源码,是一个很不错的Android源码,有兴趣的伙伴们抽时间可以看一下把。
此demo为状态栏通知小图标,notification通知,代码较为简单,可供参考