AKTUALIZACJA - 2016
Najlepszą alternatywą jest użycie RxAndroid
(specyficzne dla wiązania RxJava
) dla P
w MVP
celu przejęcie fo danych.
Zacznij od powrotu Observable
z istniejącej metody.
private Observable<PojoObject> getObservableItems() {
return Observable.create(subscriber -> {
for (PojoObject pojoObject: pojoObjects) {
subscriber.onNext(pojoObject);
}
subscriber.onCompleted();
});
}
Użyj tego obserwowalnego w ten sposób -
getObservableItems().
subscribeOn(Schedulers.io()).
observeOn(AndroidSchedulers.mainThread()).
subscribe(new Observer<PojoObject> () {
@Override
public void onCompleted() {
// Print Toast on completion
}
@Override
public void onError(Throwable e) {}
@Override
public void onNext(PojoObject pojoObject) {
// Show Progress
}
});
}
-------------------------------------------------- -------------------------------------------------- ------------------------------
Wiem, że jestem trochę spóźniony, ale proszę bardzo. Android zasadniczo działa na dwóch typach wątków, a mianowicie wątku interfejsu użytkownika i wątku tła . Według dokumentacji Androida -
Nie można uzyskać dostępu do zestawu narzędzi interfejsu użytkownika Androida spoza wątku interfejsu użytkownika, aby rozwiązać ten problem, system Android oferuje kilka sposobów uzyskiwania dostępu do wątku interfejsu użytkownika z innych wątków. Oto lista metod, które mogą pomóc:
Activity.runOnUiThread(Runnable)
View.post(Runnable)
View.postDelayed(Runnable, long)
Teraz istnieją różne metody rozwiązania tego problemu.
Wyjaśnię to przez przykład kodu:
runOnUiThread
new Thread()
{
public void run()
{
myactivity.this.runOnUiThread(new Runnable()
{
public void run()
{
//Do your UI operations like dialog opening or Toast here
}
});
}
}.start();
LOOPER
Klasa używana do uruchamiania pętli komunikatów dla wątku. Wątki domyślnie nie są powiązane z pętlą komunikatów; aby go utworzyć, wywołaj funkcję prep () w wątku, który ma uruchomić pętlę, a następnie pętlę (), aby przetwarzała komunikaty do momentu zatrzymania pętli.
class LooperThread extends Thread {
public Handler mHandler;
public void run() {
Looper.prepare();
mHandler = new Handler() {
public void handleMessage(Message msg) {
// process incoming messages here
}
};
Looper.loop();
}
}
AsyncTask
AsyncTask umożliwia wykonywanie pracy asynchronicznej w interfejsie użytkownika. Wykonuje operacje blokowania w wątku roboczym, a następnie publikuje wyniki w wątku interfejsu użytkownika, bez konieczności samodzielnego obsługiwania wątków i / lub procedur obsługi.
public void onClick(View v) {
new CustomTask().execute((Void[])null);
}
private class CustomTask extends AsyncTask<Void, Void, Void> {
protected Void doInBackground(Void... param) {
//Do some work
return null;
}
protected void onPostExecute(Void param) {
//Print Toast or open dialog
}
}
Treser
Moduł obsługi umożliwia wysyłanie i przetwarzanie obiektów Message i Runnable powiązanych z MessageQueue wątku.
Message msg = new Message();
new Thread()
{
public void run()
{
msg.arg1=1;
handler.sendMessage(msg);
}
}.start();
Handler handler = new Handler(new Handler.Callback() {
@Override
public boolean handleMessage(Message msg) {
if(msg.arg1==1)
{
//Print Toast or open dialog
}
return false;
}
});
compile 'com.shamanland:xdroid-toaster:0.0.5'
, nie wymagarunOnUiThread()
aniContext
zmiennej, cała rutyna zniknęła! wystarczy przywołaćToaster.toast(R.string.my_msg);
tutaj jest przykład: github.com/shamanland/xdroid-toaster-example