当前位置: 首页 > article >正文

Android消息通知Notification

Notification

    • 发送消息
    • 接收消息

#前言

最近在做消息通知类Notification的相关业务,利用闲暇时间总结一下。主要分为两部分来记录:发送消息和接收消息。

发送消息

发送消息利用NotificationManager类的notify方法来实现,现用最普通的方式发送:

Notification.Builder builder = new Notification.Builder(context, channelId);
builder.setSmallIcon(R.drawable.ic_launcher)
                        .setContentTitle("标题")
                        .setContentText("内容")
Notification notification = builder.build();
NotificationManager manager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
NotificationChannel notificationChannel = new NotificationChannel(channelId, name,NotificationManager.IMPORTANCE_DEFAULT);
manager.createNotificationChannel(notificationChannel);
manager.notify(R.string.app_name,notification);                      

这样一段简单的发送消息的代码就完成了。
在发送消息的时候builder可以携带很多参数,具体查看api即可,这里我记录一下我用到的一些常用的方法。

builder..addAction(icon,title,pendingIntent);

三个参数分别是int类型(api已过时),charText类型和pendingIntent意图。
这个方法我认为就很不错,比如当需要封装一个公共的弹窗,但是按钮数量和按钮颜色以及弹窗的标题不一样,这时候就可以利用这个方法进行规定。因为action是个数组,需要几个传几个就可以,比如弹窗有两个按钮,那么就传两个action过去,第一个参数传按钮的颜色值,第二个参数传按钮的名称,第三个参数传pendingIntent意图。这样就不用很复杂的实现逻辑就可以完成这个公共的弹窗。
同样,builder支持传bundle,方法如下:

Bundle bundle = new Bundle();
builder.setExtras(bundle);

bundle可以携带参数,同理刚才说的封装公共弹窗也可以用bundle传值的形式实现,但是相比较action的方式是不是就会复杂很多。
bundle可以传递一些公共的参数,比如一个type,当接收到通知的时候利用type来区分要做什么动作,这个就看项目实际需求了。
这里我把通知跳转意图的跳转activity和接收广播的代码放上来,也为自己做个记录。

Bundle bundle = new Bundle();
NotificationChannel notificationChannel = new NotificationChannel("99", "TEMP", NotificationManager.IMPORTANCE_DEFAULT);                 
Notification.Builder builder = new Notification.Builder(MainActivity.this, "99");
//Intent intent = new Intent(MainActivity.this,SecondActivity.class);
Intent intent = new Intent(MainActivity.this,MyBroadCastReceiver.class);
intent.setAction("android.intent.action.MY_BROADCAST");
intent.addCategory(Intent.CATEGORY_LAUNCHER);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
//PendingIntent pendingIntent = PendingIntent.getActivity(MainActivity.this,0,intent,PendingIntent.FLAG_CANCEL_CURRENT);
PendingIntent pendingIntent = PendingIntent.getBroadcast(MainActivity.this,0,intent,PendingIntent.FLAG_CANCEL_CURRENT);
builder.setSmallIcon(R.drawable.ic_launcher_background)
                        .setContentTitle("标题")
                        .setContentText("内容")
                        .setWhen(System.currentTimeMillis())
                        .addAction(R.color.purple_200,"确定",pendingIntent)
                        .addAction(R.color.black,"取消",pendingIntent)
                        .setExtras(bundle);
Notification notification = builder.build();
NotificationManager manager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
manager.createNotificationChannel(notificationChannel);
manager.notify(R.string.app_name,notification);

删除通知:

manager.cancel(tag,id);

这里注意的是发送通知可以是两个参数和三个参数,三个参数的方法第一个参数是tag,那么调用删除方法的时候要和这个tag对应上,就是要删除哪条消息就传哪个tag。

接收消息

接收消息我是重新创建一个类继承自NotificationListenerService,然后复写需要用到的几个方法,由于我的项目是systemui的开发,所以和实际需求上可能会略有不同。

@Override
    public void onNotificationPosted(StatusBarNotification sbn)

该方法是接收到消息通知时的回调。
我不太清楚为什么我只发送了一次通知,但在该方法中却收到了两次消息。那就想办法过滤一下吧。利用sbn返回的key和time来判断。

mPreviousNotificationKey = sbn.getKey();
mPreviousNotificationKeyTime = sbn.getPostTime();

正常创建两个变量来保存该次受到的key和postTime。然后利用sp先来获取一次上次保存的这两个值,再把该次获取的这两个值利用sp存上。

 String mPreviousNotification = spHelper.getString("notificationKey");
 Long mPreviousNotificationTime = spHelper.getLong("notificationTime");
 spHelper.putValues(new SPHelper.ContentValue("notificationKey", mPreviousNotificationKey));
 spHelper.putValues(new SPHelper.ContentValue("notificationTime", mPreviousNotificationKeyTime));

然后根据两次取值判断:

if (mPreviousNotificationKey.equals(mPreviousNotification) && mPreviousNotificationKeyTime.equals(mPreviousNotificationTime)) {
            return;
}

两次值一样直接return过滤掉。

 @Override
    public void onNotificationRemoved(StatusBarNotification sbn)

该方法是接收到删除消息的通知。
至此,结束,方便过后有类似需求查阅。


http://www.kler.cn/a/228263.html

相关文章:

  • 如何实现各种类型的进度条
  • 字符串重新排列
  • 什么是稀疏 MoE?Doubao-1.5-pro 如何以少胜多?
  • 通过视觉语言模型蒸馏进行 3D 形状零件分割
  • uiautomator2教程
  • 【系统环境丢失恢复】如何恢复和重建 Ubuntu 中的 .bashrc 文件
  • http伪造本地用户字段系列总结
  • 将xyz格式的GRACE数据转成geotiff格式
  • SOLID原理:用Golang的例子来解释
  • k8s 部署 nocas 同时部署mysql
  • 如何使用 Supabase Auth 在您的应用程序中设置身份验证
  • C/C++内存管理的底层调用逻辑
  • 使用post-css实现移动端适配
  • Leetcode 3026. Maximum Good Subarray Sum
  • gd32F470配置CAN通信
  • R语言学习case10:ggplot基础画图Parallel Coordinate Plot 平行坐标图
  • C#学习(十二)——Linq
  • 深度学习系列57: 清华大模型MiniCPM上手
  • STM32F407移植OpenHarmony笔记9
  • 算法刷题day05
  • idea常用设置
  • sentinel的Context创建流程分析
  • 【递归】 92. 反转链表 II
  • FPGA开发
  • 【Spring Boot 3】【@Scheduled】多线程执行定时任务
  • HTTP中传输协议的数据格式