JobScheduler не будет перезапущен, когда условие соответствует требованиям - PullRequest
0 голосов
/ 03 мая 2020

Я установил свой JobScheduler для запуска, когда телефон заряжается и подключен к Wi-Fi. Но когда я выключаю Wi-Fi, он говорит, что работа отменена, но когда я включаю его снова, он не перезапускается. Вот мой код:

MainActivity. java

private static final String TAG="MainActivity";
public void scheduleJob(View v) {
    ComponentName componentName = new ComponentName(this, ExampleJobService.class);
    JobInfo info = new JobInfo.Builder(123, componentName)
            .setRequiresCharging(true)
            .setRequiredNetworkType(JobInfo.NETWORK_TYPE_UNMETERED)
            .setPersisted(true)
            .setPeriodic(15 * 60 * 1000)
            .build();

    JobScheduler scheduler = (JobScheduler) getSystemService(JOB_SCHEDULER_SERVICE);
    int resultCode = scheduler.schedule(info);
    if (resultCode == JobScheduler.RESULT_SUCCESS) {
        Log.d(TAG, "Job scheduled");
    } else {
        Log.d(TAG, "Job scheduling failed");
    }
}

public void cancelJob(View v){
    JobScheduler scheduler=(JobScheduler)getSystemService(JOB_SCHEDULER_SERVICE);
    scheduler.cancel(123);
    Log.d(TAG,"Job cancelled");
}


ExampleJobService. java

private static final String TAG="ExampleJobService";
private boolean jobCanceled=false;

@Override
public boolean onStartJob(JobParameters params) {
    Log.d(TAG, "Job started");
    doBackgroundWork(params);

    return true;
}

private void doBackgroundWork(final JobParameters params) {
    new Thread(new Runnable() {
        @Override
        public void run() {
            for (int i = 0; i < 10; i++) {
                Log.d(TAG, "run: " + i);
                if (jobCanceled) {
                    return;
                }

                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }

            Log.d(TAG, "Job finished");
            jobFinished(params, false);
        }
    }).start();
}

@Override
public boolean onStopJob(JobParameters params) {
    Log.d(TAG, "Job cancelled before completion");
    jobCanceled = true;
    return true;
}

Манифест. xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.hoversfw.test">

    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <service android:name=".ExampleJobService"
            android:permission="android.permission.BIND_JOB_SERVICE"/>
    </application>

</manifest>

Когда я отключаю Wi-Fi, планирую работу, убиваю процесс приложения и включаю Wi-Fi, запускается JobScheduler, и я вижу его печать в Logcat. Кроме того, когда я планирую это и он запускается, а затем убивает приложение, оно просто перестало печатать в Logcat. Поэтому я думаю, что всякий раз, когда JobScheduler прерывается, он просто не перезапускается. У меня есть разрешения, и minSDK равен 21. Так что не должно быть никаких проблем с разрешениями. Помощь

1 Ответ

1 голос
/ 03 мая 2020

JobSchleduler будет перезапущен при вызове jobFinished(params, true). Вы можете добавить его до возвращения

if (jobCanceled) {
    jobFinished(params, true);
    return;
}
...