JobService не работает на Android Things

Я пытаюсь работать с JobScheduler и JobService на устройствах Android. Моя установка - RPI (Raspberry Pi) под управлением IoT RPI3 1.0.2.

это мой простой код:

    package com.mystuff.jobservicetest;

    import android.app.Activity;
    import android.app.job.JobInfo;
    import android.app.job.JobParameters;
    import android.app.job.JobScheduler;
    import android.app.job.JobService;
    import android.content.ComponentName;
    import android.content.Context;
    import android.os.Bundle;
    import android.util.Log;


    public class MainActivity extends Activity {

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

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        JobScheduler jobScheduler = (JobScheduler) getSystemService(
                Context.JOB_SCHEDULER_SERVICE);
        ComponentName name = new ComponentName(this, JobServiceTest.class);
        JobInfo jobInfo = new JobInfo.Builder(1,name).setPeriodic(1000).build();
        int result = jobScheduler.schedule(jobInfo);
        Log.d(TAG, "result = "+result);
    }

    public class JobServiceTest extends JobService {

        @Override
        public boolean onStartJob(JobParameters jobParameters) {
            Log.d(TAG, "Service job started");
            return false;
        }

        @Override
        public boolean onStopJob(JobParameters jobParameters) {
            return false;
        }
    }
 }

AndroidManifest.xml выглядит просто так:

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

    <application>
        <uses-library android:name="com.google.android.things" />

        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.IOT_LAUNCHER" />
                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <service android:name=".MainActivity$JobServiceTest"
            android:permission="android.permission.BIND_JOB_SERVICE"/>
    </application>

</manifest>

Результат logcat просто:

W / JobInfo: указанный интервал для 1 составляет +1s0ms. Зафиксировано до +15m0s0ms. Указанное значение flex для 1 равно +1s0ms. Зажимается до + 5m0s0ms

D / MainActivity: результат = 1

Я пропускаю журнал "Сервисное задание запущено". Кажется, onStartJob никогда не вызывается.

Есть намеки?

Спасибо

1 ответ

Решение

JobService может быть запланировано только с интервалом в 15 минут или дольше. Если вы хотите более короткую задачу, вы можете посмотреть на альтернативные методы.

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