Android Work Manager: как ставить рабочие места один раз в месяц - PullRequest
0 голосов
/ 23 декабря 2018

после этого вопроса , я посмотрел на Android Job Scheduling, и мне кажется, что Work Manager - это новейший инструмент, если я хочу что-то делать раз в месяц.Я построил класс Worker и активировал его с помощью этого фрагмента в своей деятельности:

PeriodicWorkRequest myWorkRequest =
                new PeriodicWorkRequest.Builder(MonthlyWorker.class, 20, TimeUnit.MINUTES)
                        .build();
WorkManager.getInstance().enqueueUniquePeriodicWork("my fancy test",ExistingPeriodicWorkPolicy.KEEP, myWorkRequest);

. Хотя я успешно проверил 20-минутный период, существует проблема: нет доступных TimeUnits для месяцев, только дни.Выполнение работы каждые 30 дней не будет работать по очевидным причинам, поскольку мне нужно, чтобы задача выполнялась в первый день каждого месяца.И что же мне делать?Нужно ли использовать другой API?Спасибо.

Я мог бы сделать что-то вроде if (dayOfMonth==1) do Function, но я думаю, что это подрывает цель планировщика.

1 Ответ

0 голосов
/ 27 мая 2019

Вы можете сами по минутам:

Просто конвертировать дни в минуты:

Здесь: 30 дней = 43200 минут = 1 месяц

PeriodicWorkRequest myWorkRequest =
            new PeriodicWorkRequest.Builder(MonthlyWorker.class, 43200, TimeUnit.MINUTES)
                    .build();
WorkManager.getInstance().enqueueUniquePeriodicWork("my fancy test",ExistingPeriodicWorkPolicy.KEEP, myWorkRequest);

ОБНОВЛЕНИЕ:

Согласно моему требованию, я хотел выполнять задачу каждые 30 минут в промежутке от 8 до 18:00

Спомощь того работника, которого я сделал для вас, как вам требовалось 1-е число каждого месяца в период с 12 до 2 часов ниже:

public class TestWorker extends Worker {

    private static final String DEFAULT_START_TIME = "00:01"; //12:01 am
    private static final String DEFAULT_END_TIME = "03:00"; // 03:00 am

    private static final String TAG = "TestWorker";

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

    @NonNull
    @Override
    public Result doWork() {

        /**
         * Its for time
         */
        DateFormat dateFormat = new SimpleDateFormat("HH:mm", Locale.getDefault());

        /**
         * Get Current Calendar Instance
         */
        Calendar c = Calendar.getInstance();

        // Get current day of month
        int day = c.get(Calendar.DAY_OF_MONTH);

        /**
         * Get current time and compare with our start and end date.
         */
        Date date = c.getTime();
        String formattedDate = dateFormat.format(date);

        try {
            Date currentDate = dateFormat.parse(formattedDate);
            Date startDate = dateFormat.parse(DEFAULT_START_TIME);
            Date endDate = dateFormat.parse(DEFAULT_END_TIME);

            /**
             * This condition will check that day is 1, and time interval in between give time.
             */         
            if (day == 1 && currentDate.after(startDate) && currentDate.before(endDate)) {
                // Do your work here
            }
        } catch (ParseException ignored) {

        }

        return Result.success();
    }
}

Вы можете начать эту тестовую работу для Xчасовой интервал, поэтому он будет проверять каждый X-часовой (например, в вашем случае вы можете дать 2 часа, чтобы он проверял каждые два часа)

Я не знаю, повлияет ли это на производительность илинет, но я думаю, что нет другого решения.

Вы можете начать работать, как показано ниже:

PeriodicWorkRequest periodicWork = new PeriodicWorkRequest.Builder(MyWorker.class, 2, TimeUnit.HOURS)
                .addTag("MYWORK")
                .build();

WorkManager.getInstance().enqueueUniquePeriodicWork("MYWORK", ExistingPeriodicWorkPolicy.REPLACE, periodicWork);

Надеюсь, это поможет.

...