From 92f09807eeb57f0cb9a4686cde38834549b34962 Mon Sep 17 00:00:00 2001
From: nilupeng <qingingrunt2010@qq.com>
Date: Tue, 09 Aug 2022 11:00:15 +0000
Subject: [PATCH] Merge branch 'master' into page

---
 app/src/main/java/com/runt/open/mvvm/base/model/BaseViewModel.java |   37 ++++++++++++++++++++++++++++++++++++-
 1 files changed, 36 insertions(+), 1 deletions(-)

diff --git a/app/src/main/java/com/runt/open/mvvm/base/model/BaseViewModel.java b/app/src/main/java/com/runt/open/mvvm/base/model/BaseViewModel.java
index a50ff27..de2ed52 100644
--- a/app/src/main/java/com/runt/open/mvvm/base/model/BaseViewModel.java
+++ b/app/src/main/java/com/runt/open/mvvm/base/model/BaseViewModel.java
@@ -2,10 +2,14 @@
 
 import androidx.lifecycle.ViewModel;
 
-import com.runt.open.mvvm.retrofit.observable.HttpObserver;
+import com.runt.open.mvvm.base.activities.BaseActivity;
 import com.runt.open.mvvm.retrofit.AndroidScheduler;
+import com.runt.open.mvvm.retrofit.api.CommonApiCenter;
+import com.runt.open.mvvm.retrofit.observable.HttpObserver;
+import com.runt.open.mvvm.retrofit.utils.RetrofitUtils;
 
 import io.reactivex.Observable;
+import io.reactivex.functions.Consumer;
 import io.reactivex.schedulers.Schedulers;
 
 /**
@@ -13,6 +17,12 @@
  */
 public class BaseViewModel extends ViewModel {
 
+    protected BaseActivity mActivity;
+    protected CommonApiCenter commonApi = RetrofitUtils.getInstance().getCommonApi();
+
+    public void onCreate(BaseActivity activity) {
+        this.mActivity = activity;
+    }
 
     /**
      * 网络请求观察
@@ -27,5 +37,30 @@
     }
 
 
+    /**
+     * 网络请求观察
+     * @param observable
+     * @param <T>
+     * @return
+     */
+    public <T> void httpObserverOnLoading(Observable<T> observable, HttpObserver observer){
+        observable.subscribeOn(Schedulers.io())//指定网络请求在io后台线程中进行
+                .doOnSubscribe(disposable -> {
+                    mActivity.showLoadingDialog("");
+                })
+                .observeOn(AndroidScheduler.mainThread())
+                .doOnError(new Consumer<Throwable>() {
+                    @Override
+                    public void accept(Throwable throwable) throws Exception {
+
+                    }
+                })
+                .doOnComplete(() -> {
+                    mActivity.dissmissLoadingDialog();
+                })
+                .subscribe(observer);
+    }
+
+
 
 }

--
Gitblit v1.9.1