From 485c4e60955d1a9e82c9887da7d8b71ad68ad257 Mon Sep 17 00:00:00 2001
From: nilupeng <qingingrunt2010@qq.com>
Date: Thu, 11 Aug 2022 09:58:47 +0000
Subject: [PATCH] 合并优化

---
 app/src/main/java/com/runt/open/mvvm/base/fragments/BaseFragment.java |   44 ++++++++++++++++++++++++++++++++------------
 1 files changed, 32 insertions(+), 12 deletions(-)

diff --git a/app/src/main/java/com/runt/open/mvvm/base/fragments/BaseFragment.java b/app/src/main/java/com/runt/open/mvvm/base/fragments/BaseFragment.java
index 04fab76..5918601 100644
--- a/app/src/main/java/com/runt/open/mvvm/base/fragments/BaseFragment.java
+++ b/app/src/main/java/com/runt/open/mvvm/base/fragments/BaseFragment.java
@@ -7,11 +7,11 @@
 
 import androidx.annotation.Nullable;
 import androidx.fragment.app.Fragment;
-import androidx.lifecycle.ViewModel;
 import androidx.lifecycle.ViewModelProvider;
 import androidx.viewbinding.ViewBinding;
 
 import com.runt.open.mvvm.base.activities.BaseActivity;
+import com.runt.open.mvvm.base.model.BaseViewModel;
 import com.runt.open.mvvm.base.model.ViewModelFactory;
 
 import java.lang.reflect.Method;
@@ -21,11 +21,22 @@
  * fragment 封装
  * Created by Administrator on 2021/10/28 0028.
  */
-public abstract class BaseFragment<B extends ViewBinding,VM extends ViewModel> extends Fragment {
+public abstract class BaseFragment<VB extends ViewBinding,VM extends BaseViewModel> extends Fragment {
 
-    protected BaseActivity activity;
-    protected  B binding;
-    protected  VM viewModel;
+    protected BaseActivity mActivity;
+    protected  VB mBinding;
+    protected  VM mViewModel;
+    public static final int REQUEST_CODE_LOGOUT = 20009,/*退出*/
+            REQUEST_CODE_ORDER = 10010,/*订单详情*/
+            REQUEST_CODE_LOGIN = 20010,/*登录*/
+            REQUEST_CODE_SCAN = 20011/*扫描请求*/,
+            REQUEST_CODE_PIC = 20012,/*选择图片*/
+            REQUEST_CODE_PERMISSION = 20013,/*请求权限*/
+            REQUEST_CODE_SIGN = 20014,/*签到*/
+            REQUEST_CODE_WITHDRAW = 22014,/*提现*/
+            RESULT_CODE_FAILD = 4044/*失败*/,
+            RESULT_CODE_SUCESS = 4046/*成功*/,
+            RESULT_CODE_CANCEL = 4043/*取消*/;
 
     @Nullable
     @Override
@@ -33,17 +44,23 @@
         // get genericity "B"
         try {
             final ParameterizedType type = (ParameterizedType) this.getClass().getGenericSuperclass();
-            Class<B> entityClass = (Class<B>) type.getActualTypeArguments()[0];
+            Class<VB> entityClass = (Class<VB>) type.getActualTypeArguments()[0];
             Method method = entityClass.getMethod("inflate", LayoutInflater.class,ViewGroup.class,boolean.class);//get method from name "inflate";
-            binding = (B) method.invoke(entityClass,inflater,container,false);//execute method to create a objct of viewbind;
+            mBinding = (VB) method.invoke(entityClass,inflater,container,false);//execute method to create a objct of viewbind;
             Class<VM> vmClass = (Class<VM>) type.getActualTypeArguments()[1];
-            viewModel = new ViewModelProvider(this,getViewModelFactory()).get(vmClass);
+            mViewModel = new ViewModelProvider(this,getViewModelFactory()).get(vmClass);
         } catch (Exception e) {
             e.printStackTrace();
         }
-        return binding.getRoot();
+        initViews();
+        return mBinding.getRoot();
     }
 
+    public void setOnClickListener(View.OnClickListener click,int... ids){
+        for (int id: ids){
+            getActivity().findViewById(id).setOnClickListener(click);
+        }
+    }
     public ViewModelProvider.Factory getViewModelFactory(){
         return ViewModelFactory.getInstance();
     }
@@ -51,16 +68,19 @@
     @Override
     public void onActivityCreated(@Nullable Bundle savedInstanceState) {
         super.onActivityCreated(savedInstanceState);
-        activity = (BaseActivity) getActivity();
-        initViews();
+        mActivity = (BaseActivity) getActivity();
+        mViewModel.onCreate(mActivity);
+        loadData();
     }
 
     public abstract void initViews();
 
+    public abstract void loadData();
+
     @Override
     public void onDestroyView() {
         super.onDestroyView();
-        binding = null;
+        mBinding = null;
     }
 
 }

--
Gitblit v1.9.1