当前位置: 首页 > 知识库问答 >
问题:

如何防止每次创建新通知时覆盖通知?

姬熙云
2023-03-14

我正在尝试在数据库上注册一个项目(6小时或12小时)后的特定时间发送通知。当我只注册一个项目时,通知工作良好,但是,如果我在一段时间内注册了两个项目,第一个通知将被第二个覆盖。

我知道我必须将id添加到挂起的意图中,可能还需要将id添加到实际通知中,但是我对alarmManager类不是很熟悉,也不知道应该在哪里添加id。如何使这两个通知相互独立?

NotificationHelper类:


public static class NotificationHelper extends ContextWrapper {

        public static final String channel1ID = "channel1ID";
        public static final String channel1Name = "USER1";

        private NotificationManager mManager;


        public NotificationHelper(Context base) {
            super(base);
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
                createChannels();
            }
        }

        @RequiresApi(api = Build.VERSION_CODES.O)
        private void createChannels() {

            NotificationChannel channel1 = new NotificationChannel(channel1ID, channel1Name, NotificationManager.IMPORTANCE_HIGH);
            channel1.enableLights(true);
            channel1.enableVibration(true);
            channel1.shouldVibrate();
            channel1.setShowBadge(true);
            channel1.setLightColor(R.color.colorPrimary);
            channel1.setLockscreenVisibility(Notification.VISIBILITY_PUBLIC);
            Uri uri= RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
            AudioAttributes audioAttributes = new AudioAttributes.Builder()
                    .setContentType(AudioAttributes.CONTENT_TYPE_UNKNOWN)
                    .setUsage(USAGE_NOTIFICATION)
                    .build();
            channel1.setSound(uri, audioAttributes);

            getManager().createNotificationChannel(channel1);


        }

        public NotificationManager getManager() {
            if (mManager == null) {
                mManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
            }
            return mManager;
        }


        public NotificationCompat.Builder getChannel1Notification() {
            return new NotificationCompat.Builder(getApplicationContext(), channel1ID)
                    .setContentTitle("Dressing")
                    .setContentText("Please scan the dressing on your: " + (et_DressingPos.getText().toString().trim()))
                    .setSmallIcon(R.drawable.ic_cnoticiation_scan);


        }


    }



 @Override
    public void onReceive(Context context, Intent intent) {
        Camera2Register.NotificationHelper notificationHelper = new Camera2Register.NotificationHelper(context);
        NotificationCompat.Builder nb = notificationHelper.getChannel1Notification();
        Intent intent2 = new Intent(context, Camera2.class);
        PendingIntent pendingIntent = PendingIntent.getActivity(context, 1, intent2, 0);
        nb.setContentIntent(pendingIntent);
        notificationHelper.getManager().notify(1, nb.build());
    }
}


private void startAlarmScan() {
        int requestCode = ("someString" + System.currentTimeMillis()).hashCode();

        Long time = System.currentTimeMillis();

        AlarmManager alarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
        Intent intent = new Intent(this, AlarmReceiver.class);
        intent.putExtra("randomRequestCode", requestCode);
        PendingIntent pendingIntent = PendingIntent.getBroadcast(this, requestCode, intent, 0);

        long milliseconds = 5000;
        alarmManager.setExactAndAllowWhileIdle(AlarmManager.RTC_WAKEUP, (time + milliseconds), pendingIntent);

        //}
    }

    private void startAlarmChange() {
        int requestCode = ("someString" + System.currentTimeMillis()).hashCode();

        Long time = System.currentTimeMillis();
        AlarmManager alarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
        Intent intent = new Intent(this, AlarmReceiver.class);
        intent.putExtra("randomRequestCode", requestCode);

        PendingIntent pendingIntent = PendingIntent.getBroadcast(this, requestCode, intent, 0);

        long milliseconds = 30000;

            alarmManager.setExactAndAllowWhileIdle(AlarmManager.RTC_WAKEUP, (time + milliseconds), pendingIntent2);
        //}
    }


我开始认为问题可能出在我的通知系统的结构上,是否需要一个Receiver类?在Android上的通知文档中没有提到它。

共有1个答案

狄珂
2023-03-14

您在此处使用常量值“1”作为通知id:notificationhelper.getmanager().notify(1,nb.build());

从文档:这里“如果您的应用程序已经发布了具有相同id的通知,但尚未取消,它将被更新的信息替换”

将此1更改为每个通知的唯一数字,您将看到它们全部通过。

PendingIntent pendingIntent = PendingIntent.getActivity(context, 1, intent2, 0);
 类似资料:
  • 这很好,但我现在想使用通知栏中的通知,以便跟踪下载(因为文件可能相当大,用户希望从应用程序之外跟踪)。 我已经尝试了下面的代码,但是UI开始严重滞后,我可以看到这是由于被调用太多,所以我怎么才能改变后台代码,只每秒调用

  • 我使用单信号推送通知。当android应用程序在前台收到通知时,它会创建一个带有通知的警报框。如何防止在收到通知时出现这种情况?

  • 本文向大家介绍MongoDB中如何做到更新并防止覆盖,包括了MongoDB中如何做到更新并防止覆盖的使用技巧和注意事项,需要的朋友参考一下 让我们创建一个包含文档的集合- 在find()方法的帮助下显示集合中的所有文档- 这将产生以下输出- 以下是要更新的查询- 在find()方法的帮助下显示集合中的所有文档- 这将产生以下输出-

  • 我有base/config/services。yaml在我的Symfony 4.3项目中存储了许多服务。例如: 对于我的测试目的,我有配置/测试/test_services.yaml,其中存储带有前缀的服务,以测试私有服务,使它们在test env中公开。 服务之一,在test_服务中声明。yaml没有前缀。它的名称(FQCN)与服务中定义的另一个名称相同。亚马尔。它们具有相同类型的不同构造函数参

  • 我在android中使用BottomNavigationView来制作一个像Instagram一样的应用程序。我在NavigationTabs中使用片段。应用程序有5个标签初始我已经设置为活动标签的中间标签和加载它一旦应用程序启动。当我单击任何其他选项卡时,就会进行网络调用并加载数据。现在,当我按下on back按钮或再次单击last选项卡(在启动时加载)时,片段将被重新创建,并进行网络调用以加载

  • 在聊天服务上创建任何新的公共频道,我该如何倾听?我见过,但它只适用于私有通道。 当某个通道对客户端可见时激发。为已创建和未加入的专用频道以及客户端已加入或邀请加入的所有类型的频道激发。