JobService未在Android Things上运行

时间:2018-08-14 13:48:34

标签: android-things android-jobscheduler jobservice

我尝试在Android Things上使用JobScheduler和JobService 我的安装是运行IoT RPI3 1.0.2的RPI(Raspberry Pi)

这是我的简单代码:

    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 个答案:

答案 0 :(得分:1)

JobService的间隔只能设置为15分钟或更长时间。如果您想完成较短的任务,则可能需要考虑其他方法。