2

我的目标

当我的开关被激活时,每早上 8 点收到一个通知

当前结果

- 如果我第一次激活开关,我每次启动应用程序时都会收到通知

- 我也收到通知而无需随时启动应用程序

-另外,我在一天内收到了几条通知

我做了什么(我的代码)

-NotificationActivity(onCreate 的一部分)

 private void onClickSwitch() {
        aSwitch.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                retrieveKeyWord();
                retrieveCategories();

                keywordPref = mPreferences.getString(PREF_KEYWORD, null);
                categoriesPref = mPreferences.getString(PREF_CATEGORIES, null);

                mPreferences.edit().putString(PREF_KEYWORD, keyword).apply();
                mPreferences.edit().putString(PREF_CATEGORIES, categories).apply();

                Calendar currentDate = Calendar.getInstance();
                Calendar dueDate = Calendar.getInstance();

                dueDate.set(Calendar.HOUR_OF_DAY, 8);
                dueDate.set(Calendar.MINUTE, 0);
                dueDate.set(Calendar.SECOND, 0);

                if(dueDate.before(currentDate)) {
                    dueDate.add(Calendar.HOUR_OF_DAY, 24);
                }

                long timeDiff =  dueDate.getTimeInMillis() - currentDate.getTimeInMillis();


                Constraints constraints = new Constraints.Builder()
                        .setRequiredNetworkType(NetworkType.CONNECTED)
                        .build();

                OneTimeWorkRequest oneTimeWorkRequest = new OneTimeWorkRequest.Builder(NotificationWorker.class).setInitialDelay(timeDiff, TimeUnit.MILLISECONDS)
                        .setConstraints(constraints)
                        .addTag("TAG_OUTPUT").build();


                WorkManager.getInstance().enqueue(oneTimeWorkRequest);

            }
        });
    }

-NotificationActivity -> 布局

布局

-NotificationWorker

public class NotificationWorker extends Worker {

    private SharedPreferences mPreference;
    private String keyword;
    private String categories;
    private ResultModel resultModel;
    private ResultContract.Model.OnFinishedListener onFinishedListener;
    private int numberOfArticle;


    public NotificationWorker(@NonNull Context context, @NonNull WorkerParameters workerParams) {
        super(context, workerParams);
    }

    @NonNull
    @Override
    public Result doWork() {

        mPreference = getApplicationContext().getSharedPreferences(NotificationActivity.PREFERENCE_FILE, MODE_PRIVATE);

        keyword = mPreference.getString(NotificationActivity.PREF_KEYWORD, null);
        categories = mPreference.getString(NotificationActivity.PREF_CATEGORIES, null);


        resultModel = new ResultModel();

        numberOfArticle = resultModel.getResultListWithoutDate(onFinishedListener, 1, keyword, categories);

        displayNotification(keyword);

        return Result.success();
    }


    private void displayNotification(String keyword) {

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

     if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
         NotificationChannel channel = new NotificationChannel("simplifiedcoding", "simplifiedcoding", NotificationManager.IMPORTANCE_DEFAULT);
         assert notificationManager != null;
         notificationManager.createNotificationChannel(channel);
     }

     NotificationCompat.Builder builder = new NotificationCompat.Builder(getApplicationContext(), "simplifiedcoding")
             .setContentTitle("Articles sur : " + keyword)
             .setContentText("Nombre d'articles trouvés : " + numberOfArticle)
             .setPriority(NotificationCompat.PRIORITY_DEFAULT)
             .setSmallIcon(R.drawable.ic_launcher_background);

        assert notificationManager != null;
        notificationManager.notify(1, builder.build());

    }
}

如果您需要更多信息,请告诉我,谢谢谁会帮助我

4

3 回答 3

2

你可以用3种方法来解决它。

第一的:

用户警报管理器并将其放入检查活动是否存在的 IF 中,因此如果您的应用程序打开,它将起作用。您可以从下面的谷歌文档链接中获取更多信息:

报警管理器文档

第二 :

您可以使用带有任务的计时器来创建通知,您可以检查活动是否再次活跃,但更好的用途是在前台服务上创建计时器。

第三:

即使您需要,也可以使用来自服务器的 PushNotification。文档和信息,如果链接如下:

推送通知 - 一个信号

笔记:

我建议您使用第三种方式解决您的问题。

有好的编码,别忘了给我投票;)

于 2019-10-15T06:38:06.933 回答
1

这在使用 PeriodicWorkRequest 时确实有效。诀窍是使用setInitialDelay.

fun Context.enqueueReminderWorker(
  localTime: LocalTime
) {
  val now = ZonedDateTime.now()
  val trigger = now.with(localTime)
  val realTrigger = when {
    trigger <= now -> trigger.plusDays(1)
    else -> trigger
  }

  val initialDelay = maxOf(1, realTrigger.toEpochSecond() - Instant.now().epochSecond)

  val notificationWork = PeriodicWorkRequest.Builder(NotificationWorker::class.java, 1, DAYS)
    .setInitialDelay(initialDelay, SECONDS)
    .build()

  WorkManager.getInstance(this)
    .enqueueUniquePeriodicWork(NotificationWorker.TAG, ExistingPeriodicWorkPolicy.REPLACE, notificationWork)
}

我会有PeriodicWorkRequest1 天(24 小时)的间隔,使用setInitialDelay我可以将开始时间从现在转移到我想要的起点,例如早上 8 点。NotificationWorker很简单:

class NotificationWorker(
  context: Context,
  workerParams: WorkerParameters
) : Worker(context, workerParams) {
  override fun doWork(): Result {
    // Your logic to show a notification.

    return Result.success()
  }

  companion object {
    const val TAG = "DailyReminder"
  }
}

我正在打电话Context#enqueueReminderWorkerApplication#onCreate当用户更改首选时间时。

于 2021-01-17T11:50:15.423 回答
1

由于您的目标是每天早上 8 点收到通知,我建议您使用 PeriodicWorkRequest而不是使用OneTimeWorkRequest

PeriodicWorkRequest(来自文档):

用于重复工作的 WorkRequest。这项工作会执行多次,直到被取消,第一次执行会立即发生,或者一旦满足给定的约束就会发生。下一次执行将在周期间隔内发生;请注意,执行可能会延迟,因为 WorkManager 受操作系统电池优化的影响,例如打盹模式。

OneTimeWorkRequest(来自文档):

非重复工作的 WorkRequest。

于 2019-10-15T06:59:21.747 回答