Ricerca…


Osservazioni

Attenzione ad eseguire un sacco di codice o fare lavori pesanti all'interno di JobService , ad esempio in onStartJob() . Il codice verrà eseguito sul thread principale / dell'interfaccia utente e pertanto può portare a un'interfaccia utente bloccata, all'app non più rispondente o addirittura a un arresto anomalo della tua app!

Per questo AsyncTask , è necessario scaricare il lavoro, ad esempio utilizzando un Thread o AsyncTask .

Utilizzo di base

Crea un nuovo JobService

Questo viene fatto estendendo la classe JobService e implementando / sovrascrivendo i metodi richiesti onStartJob() e onStopJob() .

public class MyJobService extends JobService
{
    final String TAG = getClass().getSimpleName();
    
    @Override
    public boolean onStartJob(JobParameters jobParameters) {
        Log.i(TAG, "Job started");

        // ... your code here ...
        
        jobFinished(jobParameters, false);  // signal that we're done and don't want to reschedule the job
        return false;                       // finished: no more work to be done
    }

    @Override
    public boolean onStopJob(JobParameters jobParameters) {
        Log.w(TAG, "Job stopped");
        return false;
    }
}

Aggiungi il nuovo JobService al tuo AndroidManifest.xml

Il seguente passaggio è obbligatorio , altrimenti non sarai in grado di eseguire il tuo lavoro:

Dichiara la tua classe MyJobService come un nuovo elemento <service> tra <application> </application> nel tuo AndroidManifest.xml .

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example">
    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        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=".MyJobService"
            android:permission="android.permission.BIND_JOB_SERVICE" />
    </application>
</manifest>

Imposta ed esegui il lavoro

Dopo aver implementato un nuovo JobService e aggiunto al tuo AndroidManifest.xml , puoi continuare con i passaggi finali.

  • onButtonClick_startJob() prepara ed esegue un lavoro periodico. Oltre ai lavori periodici, JobInfo.Builder consente di specificare molte altre impostazioni e vincoli. Ad esempio, è possibile definire che è necessario un caricatore collegato o una connessione di rete per eseguire il lavoro.
  • onButtonClick_stopJob() annulla tutti i lavori in esecuzione
public class MainActivity extends AppCompatActivity
{
    final String TAG = getClass().getSimpleName();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    public void onButtonClick_startJob(View v) {
        // get the jobScheduler instance from current context
        JobScheduler jobScheduler = (JobScheduler) getSystemService(JOB_SCHEDULER_SERVICE);

        // MyJobService provides the implementation for the job
        ComponentName jobService = new ComponentName(getApplicationContext(), MyJobService.class);

        // define that the job will run periodically in intervals of 10 seconds
        JobInfo jobInfo = new JobInfo.Builder(1, jobService).setPeriodic(10 * 1000).build();

        // schedule/start the job
        int result = jobScheduler.schedule(jobInfo);
        if (result == JobScheduler.RESULT_SUCCESS)
            Log.d(TAG, "Successfully scheduled job: " + result);
        else
            Log.e(TAG, "RESULT_FAILURE: " + result);
    }

    public void onButtonClick_stopJob(View v) {
        JobScheduler jobScheduler = (JobScheduler) getSystemService(JOB_SCHEDULER_SERVICE);
        Log.d(TAG, "Stopping all jobs...");
        jobScheduler.cancelAll(); // cancel all potentially running jobs
    }
}

Dopo aver chiamato onButtonClick_startJob() , il processo verrà eseguito approssimativamente a intervalli di 10 secondi, anche quando l'app è in stato di pausa (l'utente ha premuto il pulsante home e l'app non è più visibile).

Anziché annullare tutti i processi in esecuzione all'interno di onButtonClick_stopJob() , è anche possibile chiamare jobScheduler.cancel() per annullare un lavoro specifico in base all'ID lavoro.



Modified text is an extract of the original Stack Overflow Documentation
Autorizzato sotto CC BY-SA 3.0
Non affiliato con Stack Overflow