Ten dokument wyjaśnia, jak przenieść aplikacje, aby korzystały z biblioteki klienta WorkManager wykonywać operacje w tle, a nie korzystać z biblioteki GCMNetworkManager. Preferowanym sposobem planowania zadań w tle przez aplikację jest użycie WorkManagera. Według m.in. bibliotekę GCM, możesz włączyć w GCM do planowania zadań na urządzeniach z Androidem i interfejsem API na poziomie 22. lub niższy.
Migracja do WorkManagera
Jeśli Twoja aplikacja obecnie używa GCMNetworkManager do wykonywania operacji w tle, Wykonaj te czynności, aby przejść na platformę WorkManager.
W kolejnych krokach zakładamy, że zaczynasz od Kod GCMNetworkManager, który definiuje i planuje zadanie:
val myTask = OneoffTask.Builder() // setService() says what class does the work .setService(MyUploadService::class.java) // Don't run the task unless device is charging .setRequiresCharging(true) // Run the task between 5 & 15 minutes from now .setExecutionWindow(5 * DateUtil.MINUTE_IN_SECONDS, 15 * DateUtil.MINUTE_IN_SECONDS) // Define a unique tag for the task .setTag("test-upload") // ...finally, build the task and assign its value to myTask .build() GcmNetworkManager.getInstance(this).schedule(myTask)
// In GcmNetworkManager, this call defines the task and its // runtime constraints: OneoffTask myTask = new OneoffTask.Builder() // setService() says what class does the work .setService(MyUploadService.class) // Don't run the task unless device is charging .setRequiresCharging(true) // Run the task between 5 & 15 minutes from now .setExecutionWindow( 5 * DateUtil.MINUTE_IN_SECONDS, 15 * DateUtil.MINUTE_IN_SECONDS) // Define a unique tag for the task .setTag("test-upload") // ...finally, build the task and assign its value to myTask .build(); GcmNetworkManager.getInstance(this).schedule(myTask);
W tym przykładzie zakładamy, że MyUploadService
definiuje rzeczywistą operację przesyłania:
class MyUploadService : GcmTaskService() { fun onRunTask(params: TaskParams): Int { // Do some upload work return GcmNetworkManager.RESULT_SUCCESS } }
class MyUploadService extends GcmTaskService { @Override public int onRunTask(TaskParams params) { // Do some upload work return GcmNetworkManager.RESULT_SUCCESS; } }
Dołącz biblioteki WorkManagera
Aby używać klas WorkManager, musisz dodać bibliotekę WorkManager do swojej biblioteki zależności kompilacji. Musisz też dodać bibliotekę WorkManager GCM, umożliwia WorkManagerowi używanie GCM do planowania zadań, gdy aplikacja jest uruchomiona urządzenia, które nie obsługują funkcji JobScheduler (czyli urządzenia z interfejsem API na poziomie 22) lub niższy). Szczegółowe informacje o dodawaniu bibliotek znajdziesz w artykule Pierwsze kroki z WorkManager.
Modyfikowanie pliku manifestu
Podczas implementacji GCMNetworkManager dodano instancję
GcmTaskService
do pliku manifestu aplikacji, zgodnie z opisem w dokumencie GcmNetworkManager
.
dokumentacji referencyjnej.
GcmTaskService
sprawdza przychodzące zadanie i przekazuje je do zadania
. WorkManager zarządza przekazywaniem zadań do instancji roboczej, więc nie możesz już
potrzebują klasy, która to robi; po prostu usuń urządzenie GcmTaskService
z
pliku manifestu.
Zdefiniuj instancję roboczą
Twoja implementacja GCMNetworkManager definiuje OneoffTask
lub RecurringTask
,
który określa, co trzeba zrobić. Musisz to przepisać jako
Worker
, jak opisano w sekcji Definiowanie własnej pracy
.
Przykładowy plik GCMNetworkManager
kod
określa zadanie myTask
. Odpowiednik w środowisku WorkManager wygląda tak:
class UploadWorker(context: Context, params: WorkerParameters) : Worker(context, params) { override fun doWork() : Result { // Do the upload operation ... myUploadOperation() // Indicate whether the task finished successfully with the Result return Result.success() } }
public class UploadWorker extends Worker { public UploadWorker( @NonNull Context context, @NonNull WorkerParameters params) { super(context, params); } @Override public Result doWork() { // Do the upload operation ... myUploadOperation() // Indicate whether the task finished successfully with the Result return Result.success() } }
Występuje kilka różnic między zadaniem GCM a Worker
:
- GCM przekazuje parametry do zadania za pomocą obiektu
TaskParams
. FunkcjaWorkManager
używa danych wejściowych, które możesz określić w obiekcieWorkRequest
, np. opisane w dokumentacjiWorkManager
dotyczącej definiowania wejścia/wyjścia dla Twoim zadaniem. W obu przypadkach możesz przekazywać pary klucz/wartość, określając dowolne parametry wymagane przez zadanie. GcmTaskService
sygnalizuje sukces lub niepowodzenie, zwracając flagi takie jakGcmNetworkManager.RESULT_SUCCESS
Aplikacja WorkManagerWorker
sygnalizuje swoje wyniki za pomocąListenableWorker.Result
. , np.ListenableWorker.Result.success()
, i zwraca wartość zwracaną tej metody.- Jak już wspomnieliśmy, nie określasz ograniczeń ani tagów przy definiowaniu
Worker
; zrobisz to w następnym kroku, podczas tworzeniaWorkRequest
Planowanie zlecenia roboczego
Zdefiniowanie elementu Worker
określa, co należy zrobić. Aby określić, kiedy utwór
należy określić
WorkRequest
:
- Tworzenie
OneTimeWorkRequest
lubPeriodicWorkRequest
, oraz ustaw odpowiednie ograniczenia określające, kiedy zadanie ma być uruchamiane, a także znaczniki identyfikujące Twoją pracę. - Przekaż prośbę do
WorkManager.enqueue()
umieścić zadanie w kolejce do wykonania.
Na przykład w poprzedniej sekcji pokazaliśmy, jak przekonwertować
OneoffTask
równoważnej wartości Worker
. W przypadku reguły Worker
nie uwzględniono jednak
ograniczenia wykonania obiektu OneoffTask
oraz tag. Zamiast tego ustawimy parametr
i identyfikatora zadania podczas tworzenia obiektu WorkRequest
. Określimy też
aby zadanie nie zostało uruchomione bez połączenia sieciowego. Nie potrzebujesz
bezpośrednio zażądać połączenia sieciowego za pomocą GCMNetworkManager, ponieważ
GCMNetworkManager domyślnie wymaga połączenia sieciowego, ale WorkManager wymaga
nie wymagają połączenia sieciowego, chyba że dodasz to ograniczenie.
Gdy zdefiniujesz usługę WorkRequest
, umieścimy ją w kolejce w WorkManageru.
val uploadConstraints = Constraints.Builder() .setRequiredNetworkType(NetworkType.CONNECTED) .setRequiresCharging(true).build() val uploadTask = OneTimeWorkRequestBuilder<UploadWorker>() .setConstraints(uploadConstraints) .build() WorkManager.getInstance().enqueue(uploadTask)
Constraints uploadConstraints = new Constraints.Builder() .setRequiredNetworkType(NetworkType.CONNECTED) .setRequiresCharging(true) .build(); OneTimeWorkRequest uploadTask = new OneTimeWorkRequest.Builder(UploadWorker.class) .setConstraints(uploadConstraints) .build(); WorkManager.getInstance().enqueue(uploadTask);
Mapowania interfejsów API
W tej sekcji opisujemy, jak mapowane są niektóre funkcje i ograniczenia GCMNetworkManager na ich odpowiedniki z WorkManagera.
Mapowania ograniczeń
GCMNetworkManager pozwala ustawić różne ograniczenia dotyczące sytuacji, w których zadanie powinno bieganie. W większości przypadków istnieje wyraźne równoważne ograniczenie WorkManager. Ten zawiera ich listę.
Ustaw ograniczenia dotyczące zadań GCMNetworkManager, wywołując odpowiednią metodę w
obiekt konstruktora zadania; Możesz na przykład określić wymagania dotyczące sieci,
Wywołuję: Task.Builder.setRequiredNetwork()
.
W usłudze WorkManager tworzysz
Constraints.Builder
i
wywołuje metody tego obiektu, aby ustawić ograniczenia (na przykład
Constraints.Builder.setRequiredNetworkType())
,
a następnie za pomocą konstruktora utwórz obiekt Constraints, który będzie można dołączyć do
w ramach pracy. Więcej informacji znajdziesz w artykule Definiowanie własnej pracy
.
Ograniczenie GCMNetworkManager | Odpowiednik w usłudze WorkManager | Uwagi |
---|---|---|
setPersisted() |
(niewymagane) | Wszystkie zadania WorkManager są zachowywane po ponownym uruchomieniu urządzenia |
setRequiredNetwork() |
setRequiredNetworkType() |
Domyślnie GCMNetworkManager wymaga dostępu do sieci. WorkManager domyślnie nie wymaga dostępu do sieci. Jeśli Twoje zadanie wymaga dostępu do sieci, musisz użyć sieci setRequiredNetworkType(CONNECTED) lub ustawić bardziej szczegółowy typ sieci. |
setRequiresCharging() |
Inne mapowania
Oprócz ograniczeń w usłudze GCMNetworkManager możesz stosować też inne ustawienia. zadania. W tej sekcji znajdziesz informacje o sposobie stosowania tych ustawień do Zadanie WorkManager.
Tagi
Wszystkie zadania usługi GCMNetworkManager muszą zawierać ciąg tagu ustawiany przez wywołanie metody
Budowniczy setTag()
. Zadania WorkManager są jednoznacznie identyfikowane przez identyfikator, który jest:
generowane automatycznie przez WorkManagera; można go uzyskać, dzwoniąc
WorkRequest.getId()
W
żądania służbowe mogą opcjonalnie mieć jeden lub więcej tagów. Aby ustawić tag dla
zadanie WorkManager, wywołaj funkcję
WorkRequest.Builder.addTag()
przed użyciem tego konstruktora do utworzenia WorkRequest
.
W GCMNetworkManager możesz wywoływać
setUpdateCurrent()
, aby określić, czy zadanie ma zastąpić istniejące zadanie tym samym tagiem.
Odpowiednikiem w usłudze WorkManager jest umieszczenie zadania w kolejce przez wywołanie
enqueueUniqueWork()
lub enqueueUniquePeriodicWork()
;
jeśli korzystasz z tych metod, nadajesz zadaniu unikalną nazwę, a także określasz, jak
WorkManager powinien obsłużyć żądanie, jeśli istnieje już oczekujące zadanie z tym
imię i nazwisko. Więcej informacji znajdziesz w sekcji Obsługa unikalnych użytkowników
w pracy.
Parametry zadania
Parametry możesz przekazać do zadania GCMNetworkManager, wywołując
Task.Builder.setExtras()
i przekazywanie Bundle
z parametrami. WorkManager pozwala przekazać
obiekt Data
do zadania WorkManager, który zawiera parametry jako para klucz-wartość
pary. Więcej informacji:
Przypisz dane wejściowe.