Android
Planowanie pracy
Szukaj…
Uwagi
Uważaj na uruchamianie dużej ilości kodu lub ciężką pracę wewnątrz JobService
, na przykład w onStartJob()
. Kod będzie działał w wątku main / UI, a zatem może prowadzić do zablokowania interfejsu użytkownika, braku odpowiedzi aplikacji lub nawet awarii aplikacji!
Z tego powodu musisz odciążyć pracę, na przykład za pomocą Thread
lub AsyncTask
.
Podstawowe użycie
Utwórz nową JobService
Odbywa się to poprzez rozszerzenie klasy JobService
i wdrożenie / onStartJob()
wymaganych metod onStartJob()
i 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;
}
}
Dodaj nową JobService do pliku AndroidManifest.xml
Poniższy krok jest obowiązkowy , w przeciwnym razie nie będziesz mógł uruchomić swojej pracy:
Zadeklaruj swoją klasę MyJobService
jako nowy element <service>
między <application> </application>
w pliku 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>
Skonfiguruj i uruchom zadanie
Po zaimplementowaniu nowego JobService i dodaniu go do pliku AndroidManifest.xml możesz przejść do ostatnich kroków.
-
onButtonClick_startJob()
przygotowuje i uruchamia zadanie okresowe. Oprócz zadań okresowychJobInfo.Builder
pozwala określić wiele innych ustawień i ograniczeń. Na przykład możesz zdefiniować, że do uruchomienia zadania wymagana jest podłączona ładowarka lub połączenie sieciowe . -
onButtonClick_stopJob()
anuluje wszystkie uruchomione zadania
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
}
}
Po wywołaniu onButtonClick_startJob()
zadanie będzie działać w przybliżeniu w odstępach 10 sekund, nawet gdy aplikacja jest w stanie wstrzymania (użytkownik wcisnął przycisk Home i aplikacja nie jest już widoczna).
Zamiast anulować wszystkie uruchomione zadania w funkcji onButtonClick_stopJob()
, możesz także wywołać jobScheduler.cancel()
aby anulować określone zadanie na podstawie jego identyfikatora.