Workmanager не работает в режиме ожидания и в режиме ожидания

Я использую WorkManager, который планирует мои уведомления, он работает, когда мой смартфон активен, но не работает, когда мой смартфон находится в режиме ожидания. Зачем? Есть какое-то ограничение, которое позволяет мне это? Или как?

Метод notifyPush в CoreActivity.java

public static void notifyPush(String message, Context context)
    {

        //codice di un altro programma

        // Make a channel if necessary
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
            // Create the NotificationChannel, but only on API 26+ because
            // the NotificationChannel class is new and not in the support library
            CharSequence name = Constants.VERBOSE_NOTIFICATION_CHANNEL_NAME;
            String description = Constants.VERBOSE_NOTIFICATION_CHANNEL_DESCRIPTION;
            int importance = NotificationManager.IMPORTANCE_HIGH;
            NotificationChannel channel = new NotificationChannel(CHANNEL_ID, name, importance);
            channel.setDescription(description);

            // Add the channel
            NotificationManager notificationManager =
                    (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);

            if (notificationManager != null) {
                notificationManager.createNotificationChannel(channel);
            }
        }

        // Create the notification
        NotificationCompat.Builder builder = new NotificationCompat.Builder(context, CHANNEL_ID)
                .setSmallIcon(R.drawable.ic_launcher_foreground)
                .setContentTitle(Constants.NOTIFICATION_TITLE)
                .setContentText(message)
                .setPriority(NotificationCompat.PRIORITY_HIGH)
                .setDefaults(DEFAULT_ALL);
                //.setVibrate(new long[0]);

        // Show the notification
        NotificationManagerCompat.from(context).notify(Constants.NOTIFICATION_ID, builder.build());
    }

NotifyWorker.java

package com.example.msnma.movienotifier.notify;


import android.content.Context;
import android.support.annotation.NonNull;
import android.util.Log;

import com.example.msnma.movienotifier.CoreActivity;

import androidx.work.Data;
import androidx.work.Worker;

import static com.example.msnma.movienotifier.CoreActivity.notifyPush;
import static com.example.msnma.movienotifier.notify.Constants.KEY_MOVIE;

public class NotifyWorker extends Worker {

    //private static final String TAG = BlurWorker.class.getSimpleName();

    @NonNull
    @Override
    public Worker.Result doWork() {

        Context applicationContext = getApplicationContext();

        String message = getInputData().getString(Constants.KEY_MOVIE);

        //setOutputData(new Data.Builder().putString(
                //KEY_MOVIE, message.toString()).build());

        try {



            notifyPush(message , applicationContext);
            return Worker.Result.SUCCESS;
        } catch (Throwable throwable) {

            // Technically WorkManager will return WorkerResult.FAILURE
            // but it's best to be explicit about it.
            // Thus if there were errors, we're return FAILURE
            Log.e("NotifyWorker", "Error notification", throwable);
            return Worker.Result.FAILURE;
        }
    }
}

Методы scheduleNotify и deleteNotify в MovieAdapter.java

private UUID scheduleNotify(Date d, int position)
    {
        long currentTime= System.currentTimeMillis();
        //Calendar c = new Date;
        long specificTimeToTrigger = d.getTime();
                //d.getTimeToMillis();
        long delayToPass = specificTimeToTrigger - currentTime;

        /*OneTimeWorkRequest compressionWork =
                new OneTimeWorkRequest.Builder(NotifyWorker.class)
                        .setInputData(message)
                        .setInitialDelay(delayToPass, TimeUnit.MILLISECONDS)
                        .build();*/

        //inizialmente è molto semplice la notifica
        OneTimeWorkRequest notifyRequest =
                new OneTimeWorkRequest.Builder(NotifyWorker.class)
                        .setInputData(createInputDataForUri(movies.get(position)))
                        .setInitialDelay(delayToPass,TimeUnit.MILLISECONDS)
                        .build();
        mWorkManager.enqueue(notifyRequest);
        UUID notify_ID = notifyRequest.getId();

        //WorkManager.getInstance().enqueue(compressionWork);

        return notify_ID;

    }

    public void deleteNotify(UUID notify_ID)
    {
        WorkManager.getInstance().cancelWorkById(notify_ID);
    }

1 ответ

WorkManager использования JobScheduler и это будет пакетных заданий во время обслуживания окна, чтобы оптимизировать использование батареи.

Кроме того, вот ограничение, которое вы ищете.

Мой новый фрагмент кода:

@RequiresApi(api = Build.VERSION_CODES.M) 
    private UUID scheduleNotify(Date d, int position)
        {

            Constraints myConstraints = new Constraints.Builder()
                        .setRequiresDeviceIdle(true)
                        .build();

            long currentTime= System.currentTimeMillis();
            //Calendar c = new Date;
            long specificTimeToTrigger = d.getTime();
                    //d.getTimeToMillis();
            long delayToPass = specificTimeToTrigger - currentTime;

            /*OneTimeWorkRequest compressionWork =
                    new OneTimeWorkRequest.Builder(NotifyWorker.class)
                            .setInputData(message)
                            .setInitialDelay(delayToPass, TimeUnit.MILLISECONDS)
                            .build();*/

            //inizialmente è molto semplice la notifica
            OneTimeWorkRequest notifyRequest =
                    new OneTimeWorkRequest.Builder(NotifyWorker.class)
                            .setInputData(createInputDataForUri(movies.get(position)))
                            .setConstraints(myConstraints)
                            .setInitialDelay(delayToPass,TimeUnit.MILLISECONDS)
                            .build();
            mWorkManager.enqueue(notifyRequest);
            UUID notify_ID = notifyRequest.getId();

            //WorkManager.getInstance().enqueue(compressionWork);

            return notify_ID;

        }

Теперь это не работает также, когда смартфон активен, я добавил myConstraints и требуемый Api - Marshmallow (6.0, в то время как моя версия android - 7.0). Помоги мне!

Начиная с версии 1.0.0-alpha06
Ошибка, из-за которой PeriodicWork не запускался по расписанию, когда в режиме Doze был остановлен.

https://issuetracker.google.com/issues/111469837

Другие вопросы по тегам