Notification的作用

Notification是一种全局效果的通知,在系统的通知栏中显示。既然作为通知,其基本作用有:

显示接收到短消息、即时信息等

显示客户端的推送(广告、优惠、新闻等)

显示正在进行的事物(后台运行的程序,如音乐播放进度、下载进度)

Notification的基本操作:

Notification的基本操作主要有创建、更新和取消三种。一个Notification的必要属性有三项,如果不设置的话在运行时会抛出异常:

小图标,通过setSmallIcon方法设置

标题,通过setContentTitle方法设置

内容,通过setContentText方法设置。

除了以上三项,其他均为可选项,不过一般而言,通知需要有交互的功能,所以一般Notification具有Action属性,这样就能跳转到App的某一个Activity、启动一个service或者发送一个Broadcast。

当系统受到通知时,可以通过震动、铃声、呼吸灯等多种方式进行提醒。

下面就从Notification的基本操作逐条介绍:

Notification的创建

Notification的创建过程主要涉及到Notification.Builder、Notification、NotificationManager

Notification.Builder:

使用建造者模式构建Notification对象。由于Notification.Builder仅支持Android4.1及之后的版本,为了解决兼容性的问题,使用V4兼容库中的NotifivationCompat.Builder类。

Notification:通知对应类,保存通知相关的数据。NotificationManager向系统发送通知时会用到。

NotificationManager:通知管理类,调用NotificationManager的notify方法可以向系统发送通知。

获取 NotificationManager 对象:

NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

前面讲到,Notification有三个必要属性以及一个很有必要的属性Action。下面我们就创建一个简单的Notification,主要有以下三步:

获取NotificationManager实例

实例化NotificationCompat.Builder并设置相关属性

通过builder.build方法来生成Notification对象,并发送通知

private voidsendNotification(){

Intent intent= new Intent(this,SettingsActivity.class);

PendingIntent mPendingIntent= PendingIntent.getActivity(this,0,intent,PendingIntent.FLAG_ONE_SHOT);

NotificationManager notificationManager=(NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

NotificationCompat.Builder builder= (NotificationCompat.Builder) new NotificationCompat.Builder(this)//设置小图标

.setSmallIcon(R.mipmap.ic_launcher)//点击后自动清除

.setAutoCancel(true)//设置通知标题

.setContentTitle("最简单的通知")//设置通知内容

.setContentText("真的很简单很简单很简单")//设置通知的动作

.setContentIntent(mPendingIntent)//设置通知时间,默认为系统发出通知的时间

.setWhen(System.currentTimeMillis());//第一个参数为Notification的id

notificationManager.notify(2,builder.build());

}

其中为了实现Action属性,我们需要创建Intent、PendingIntent和setContentIntent()这几步。

不难发现,其中的PendingIntent的设置才是其中的关键。

PendingIntent支持三种待定的意图:启动Activity,启动Service和发送Broadcast。对应于它的三个接口方法。

static PendingIntent

getActivity(Context context,int requestCode,Intent intent,int flags)

获取一个PendingIntent,该意图发生时,相当于Context.startActivity(Intent)

static PendingIntent

getService (Context context,int requestCode,Intent intent,int flags)

获取一个PendingIntent,该意图发生时,相当于Context.startService (Intent)

static PendingIntent

getBroadcast(Context context,int requestCode,Intent intent,int flags)

获取一个PendingIntent,该意图发生时,相当于Context.sendBroadcast(Intent)

其中context和intent不需要讲,主要说一下requestCode和flags。其中requestCode是PendingIntent发送发的请求码,多数情况下设置为0即可,requestCode会影响到flags的效果。

PendingIntent相同:Intent相同且requestCode也相同。(Intent相同需要ComponentName和intent-filter相同)

flags的常见类型有:

FLAG_ONE_SHOT:只能被使用一次,然后就会被自动cancel,如果后续还有相同的PendingIntent。那么他们的send方法就会调用失败。

FLAG_NO_CREATE:如果当前系统中不存在相同的PendingIntent对象,系统不会创建该PendingIntent对象,而是直接返回null。(很少使用)

FLAG_CANCEL_CURRENT:如果当前系统中已经存在一个相同的 PendingIntent 对象,那么就将先将已有的 PendingIntent 取消,然后重新生成一个 PendingIntent 对象。

FLAG_UPDATE_CURRENT:当前描述的PendingIntent如果已经存在,那么它们会被更新,即Intent中的Extras会被替换到最新的。

Notification的更新

更新通知的操作很简单,只需要再次发送一次相同ID的通知即可,如果之前的通知还没有被取消,则会直接更新该通知相关的属性;如果之前的通知已经被取消,则会重新创建一个新的通知。

更新通知和发送通知采用同样的方法。

Notification的取消

取消通知的方式主要有以下5种:

点击通知栏的清除按钮,会清除所有可清除的通知

设置了setAutoCancel()或者设置了flags为FLAG_AUTO_CANCEL的通知,点击通知时会自动清除。

通过NotificationManager调用cancel(int id)来取消指定id的通知

通过NotificationManager调用cancel(String tag,int id)方法清除指定Tag和ID的通知。

通过NotificationManager调用cancelAll()清除所有该应用之前发送的通知

如果是通过NotificationManager.notify(String tag, int id, Notification notify) 方法创建的通知,那么只能通过 NotificationManager.cancel(String tag, int id) 或cancelAll()方法才能清除对应的通知,调用NotificationManager.cancel(int id) 无效。

Notification的通知效果

前面提到了Notification的通知效果,有了通知效果更能提醒用户去查看Notification。

Notification的通知效果有震动、呼吸灯、铃声三种,可以通过builder中的setDefaults(int defaults)方法来设置,属性有以下四种,一旦设置了默认效果,自定义效果就会失效。

//添加默认震动效果,需要申请震动权限//

Notification.DEFAULT_VIBRATE//添加系统默认声音效果,设置此值后,调用setSound()设置自定义声音无效

Notification.DEFAULT_SOUND//添加默认呼吸灯效果,使用时须与 Notification.FLAG_SHOW_LIGHTS 结合使用,否则无效

Notification.DEFAULT_LIGHTS//添加上述三种默认提醒效果

Notification.DEFAULT_ALL

铃声:

//调用系统默认响铃,设置此属性后setSound()会无效//.setDefaults(Notification.DEFAULT_SOUND)//调用系统多媒体裤内的铃声//.setSound(Uri.withAppendedPath(MediaStore.Audio.Media.INTERNAL_CONTENT_URI,"2"));//调用自己提供的铃声,位于 /res/values/raw 目录下

.setSound(Uri.parse("android.resource://com.littlejie.notification/" + R.raw.sound))

震动:

long[] vibrate = new long[]{0, 500, 1000, 1500};//使用系统默认的震动参数,会与自定义的冲突//.setDefaults(Notification.DEFAULT_VIBRATE)//自定义震动效果

.setVibrate(vibrate);

呼吸灯

//ledARGB 表示灯光颜色、 ledOnMS 亮持续时间、ledOffMS 暗的时间

.setLights(0xFF0000, 3000, 3000);

另一种方式:

Notification notification =builder.build();//只有在设置了标志符Flags为Notification.FLAG_SHOW_LIGHTS的时候,才支持呼吸灯提醒。

notify.flags=Notification.FLAG_SHOW_LIGHTS;//设置lights参数的另一种方式//notify.ledARGB = 0xFF0000;//notify.ledOnMS = 500;//notify.ledOffMS = 5000;

还可以通过以下几种Flag来设置通知效果

//提醒效果常用 Flag//三色灯提醒,在使用三色灯提醒时候必须加该标志符

Notification.FLAG_SHOW_LIGHTS//发起正在运行事件(活动中)

Notification.FLAG_ONGOING_EVENT//让声音、振动无限循环,直到用户响应 (取消或者打开)

Notification.FLAG_INSISTENT//发起Notification后,铃声和震动均只执行一次

Notification.FLAG_ONLY_ALERT_ONCE//用户单击通知后自动消失

Notification.FLAG_AUTO_CANCEL//只有调用NotificationManager.cancel()时才会清除

Notification.FLAG_NO_CLEAR//表示正在运行的服务

Notification.FLAG_FOREGROUND_SERVICE

上面讲到的Notification的布局都是系统默认的,当然有时候处于需求,我们可能需要自定义Notification的布局。

那如何实现Notification的自定义布局呢?

这里就需要提出一个新的知识点RemoteView,望文生义,即远程View。

RemoteView表示的是一种View结构,它可以在其他进程中显示(具体来讲是SystemServer进程),由于它是在其他进程中显示,为了更新它的界面,我们不能简单地使用普通View的那一套方法,RemoteView提供了一系列Set方法用于更新界面。

下面就是一个简单的示例;

packagecom.pignet.remoteviewtest;importandroid.app.Notification;importandroid.app.NotificationManager;importandroid.app.PendingIntent;importandroid.content.Context;importandroid.content.Intent;importandroid.support.v7.app.AppCompatActivity;importandroid.os.Bundle;importandroid.view.View;importandroid.widget.Button;importandroid.widget.RemoteViews;public class MainActivity extendsAppCompatActivity {

@Overrideprotected voidonCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

Button btnNotification=(Button) findViewById(R.id.btn_notification);

btnNotification.setOnClickListener(newView.OnClickListener() {

@Overridepublic voidonClick(View v) {

sendNotification();

}

});

}private voidsendNotification(){

NotificationManager notificationManager=(NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

Notification notification=newNotification();

notification.icon=R.mipmap.ic_launcher;

notification.when=System.currentTimeMillis();

notification.flags=Notification.FLAG_AUTO_CANCEL;//跳转意图

Intent intent= new Intent(this,SettingsActivity.class);//建立一个RemoteView的布局,并通过RemoteView加载这个布局

RemoteViews remoteViews= newRemoteViews(getPackageName(),R.layout.layout_notification);//为remoteView设置图片和文本

remoteViews.setTextViewText(R.id.message,"第一条通知");

remoteViews.setImageViewResource(R.id.image,R.mipmap.ic_launcher_round);//设置PendingIntent

PendingIntent pendingIntent= PendingIntent.getActivity(this,0,intent,PendingIntent.FLAG_UPDATE_CURRENT);//为id为openActivity的view设置单击事件

remoteViews.setOnClickPendingIntent(R.id.openActivity,pendingIntent);//将RemoteView作为Notification的布局

notification.contentView=remoteViews;//将pendingIntent作为Notification的intent,这样当点击其他部分时,也能实现跳转

notification.contentIntent=pendingIntent;

notificationManager.notify(1,notification);

}

}

有图:

android 自定义推送布局_Notification的基本用法以及使用RemoteView实现自定义布局相关推荐

  1. Android 消息推送:个推

    之前一直在使用极光推送,这次项目打算使用个推试试! 集成失败原因: 1.检查自己的APPID等信息 2.检查自己的.jar和.so文件 3.检查AndroidManifest.xml <!-- ...

  2. Android 极光推送 自定义通知铃声

    公司使用的推送功能使用的是极光推送,对于普通的通知,极光推送API自动集成了声音的提示,但是对于一些特殊的情况,我们就需要自定义声音提示. 有点坑的是极光并没有提供设置自定通知铃声的接口,所以只能自己 ...

  3. 自定义Android消息推送提示音

    在自定义推送通知声音的时候,推送如果不是使用自定义消息,而是应用平台默认的通知的话,一般可能没有办法设置自定义的声音.解决办法. 为了修改自定义声音可以使用自定义消息,但是为了不增加额外的工作量,可以 ...

  4. android极光推送声音,【极光推送】iOS APNS 自定义铃声

    IOS APNS自定义推送铃声 是推送给苹果服务器时 将 推送的 key = sound 的value = @"custom.xxx".自定义铃声支持几种固定的格式.本人只以.ca ...

  5. android极光推送声音,Android 极光推送JPush---自定义提示音

    public classMyReceiver extends BroadcastReceiver {private static final String TAG = MyReceiver.class ...

  6. 腾讯信鸽自定义推送通知

    使用信鸽的过程,感觉一路艰辛,各种坑,想必各位使用过的也是深有体会的吧.而且官方文档也太简洁了.demo功能也不全,没办法只能自己摸索着来,这不刚把自定义通知弄明白,就给各位看官献上来了. 1. XG ...

  7. android极光推送判断消息,通过极光推送给Android所有用户发送推送消息

    https://www.cnblogs.com/yueguanguanyun/p/8485381.html 所需jar包,在maven中添加下列依赖: cn.jpush.api jpush-clien ...

  8. Android 消息推送OnePush

    Android 消息推送 1.实现原理 1.消息推送的实质 实际上,是当服务器有新消息需推送给用户时,先发送给应用App,应用App再发送给用户 推送的消息一般是用户需要的或app希望用户知道的消息 ...

  9. 【android极光推送】—从客户端到后台,一文通吃

    前记 推送原理浅析 平台说明 概念解释 推送的三种实现方式 客户端直接向推送服务方发送Http请求 项目服务器通过Http转发推送请求至推送服务方 项目服务端使用SDK进行功能集成 关于推送的种类概述 ...

最新文章

  1. 不降低scipy版本解决AttributeError: module ‘scipy.misc‘ has no attribute ‘imresize‘问题
  2. 从零入门 FreeRTOS操作系统之信号量
  3. QEMU 1.3 发布,模拟处理器
  4. Vimdiff---VIM的比较和合并工具
  5. 【theano-windows】学习笔记十四——堆叠去噪自编码器
  6. 【转载】网易将军令工作原理
  7. 《学习OpenCV》课后习题解答(第三章)(仅供参考)
  8. 《强化学习》中的时序差分控制:Sarsa、Q-learning、期望Sarsa、双Q学习 etc.
  9. 阶段1 语言基础+高级_1-3-Java语言高级_07-网络编程_第3节 综合案例_文件上传_4_综合案例_文件上传案例阻塞问题...
  10. Unix/Linux/BSD命令大全|实用指南
  11. 关于微信小程序上线流程的简单总结
  12. MMD动作下载:世界第一公主殿下 World Is Mine Project DIVA
  13. RadioButton设置图片大小
  14. [CTF]天下武功唯快不破
  15. 目前最为出色的Wii模拟器,可以在电脑上运行绝大多数Wii游戏,对低端配置完美支持,绝对的神器!
  16. 周口女子职专计算机分为哪些专业,周口女子职业中专学校
  17. Oracle 12C Sharding分片数据库
  18. 打破传统桎梏,挑战性能巅峰,网友:这轻薄本性能强的像游戏本
  19. Response to preflight request do‘nt access control check: Redirect is not allow for a preflight re.
  20. 《Happy Birthday》游戏开发记录(送给朋友的小礼物)

热门文章

  1. 嵌入式开发常见英文单词及缩写
  2. 软考下午——数据流图
  3. 【6.15日报】Web后端类与方法设计(二)——开发日报(二)
  4. VMware vcenter/ESXI系列漏洞总结
  5. python------多线程(锁)
  6. 广告数仓:数仓搭建(二)
  7. (附源码)mysql+ssm芜湖公共书房服务平台 毕业设计 250859
  8. (附源码)php+mysql+基于django的图书商城管理系统 毕业设计110938
  9. 计算机u盘病毒清除方式,如何操作才能将U盘中的病毒彻底?两种方法即可清除...
  10. 2023.3.13-3.19 AI行业周刊(第141期):再回母校的心得分享