From 82e57df230ecb744af6c8865f80870ba03c86d89 Mon Sep 17 00:00:00 2001
From: Linjiajia <319408893@qq.com>
Date: 星期二, 25 七月 2023 22:18:27 +0800
Subject: [PATCH] 基本功能完成

---
 app/src/main/java/com/application/zhangshi_app_android/ui/function/FunctionFragment.java |  154 ++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 139 insertions(+), 15 deletions(-)

diff --git a/app/src/main/java/com/application/zhangshi_app_android/ui/function/FunctionFragment.java b/app/src/main/java/com/application/zhangshi_app_android/ui/function/FunctionFragment.java
index c5ec593..41e34d6 100644
--- a/app/src/main/java/com/application/zhangshi_app_android/ui/function/FunctionFragment.java
+++ b/app/src/main/java/com/application/zhangshi_app_android/ui/function/FunctionFragment.java
@@ -2,20 +2,43 @@
 
 import android.os.Bundle;
 import android.view.View;
+import android.view.ViewGroup;
+import android.widget.FrameLayout;
+import android.widget.ImageView;
+import android.widget.PopupWindow;
 
-import com.android.app_base.base.view.BaseFragment;
+import androidx.fragment.app.Fragment;
+import androidx.fragment.app.FragmentTransaction;
+import androidx.lifecycle.Observer;
+
 import com.android.app_base.manager.AppManager;
+import com.android.app_base.utils.GlideUtil;
+import com.android.app_base.utils.ScreenSizeUtils;
 import com.application.zhangshi_app_android.BR;
 import com.application.zhangshi_app_android.R;
+import com.application.zhangshi_app_android.bean.BannerBean;
 import com.application.zhangshi_app_android.databinding.FragmentFunctionBinding;
+import com.application.zhangshi_app_android.ui.DLBaseFragment;
+import com.application.zhangshi_app_android.ui.TestActivity;
+import com.application.zhangshi_app_android.ui.home.HomeFragment;
+import com.application.zhangshi_app_android.ui.main.MainActivity;
+
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
 
 /**
  * @author Ljj
  * @date 2023.03.15. 20:14
  * @desc 鍔熻兘 Fragment
  */
-public class FunctionFragment extends BaseFragment<FragmentFunctionBinding,FunctionFragmentViewModel> {
-    public FunctionFragment() {
+public class FunctionFragment extends DLBaseFragment<FragmentFunctionBinding,FunctionFragmentViewModel> {
+
+    private PopupWindow mOperatePopupWindow;
+    private ImageCarouselFragment imageCarouselFragment;
+    private VideoFragment videoFragment;
+
+    private FunctionFragment() {
     }
 
     public static FunctionFragment newInstance() {
@@ -41,6 +64,12 @@
 
     @Override
     protected void initView() {
+        binding.layoutHomeRootNet.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View v) {
+                MainActivity.start(getSelfActivity(), HomeFragment.class);
+            }
+        });
         binding.layoutFamilyMemorabilia.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View view) {
@@ -59,28 +88,111 @@
                 AppManager.getAppManager().startActivity(FamilyAssetsActivity.class);
             }
         });
-        binding.layoutHomeDevices.setOnClickListener(new View.OnClickListener() {
-            @Override
-            public void onClick(View view) {
-                AppManager.getAppManager().startActivity(HomeDevicesActivity.class);
-            }
+        binding.layoutHomeDevices.setOnClickListener(view -> {
+            AppManager.getAppManager().startActivity(HomeDevicesActivity.class);
         });
-        binding.layoutGrowingUp.setOnClickListener(new View.OnClickListener() {
-            @Override
-            public void onClick(View view) {
-                AppManager.getAppManager().startActivity(GrowthExperienceActivity.class);
+        binding.layoutGrowingUp.setOnClickListener(view -> {
+            AppManager.getAppManager().startActivity(GrowthExperienceActivity.class);
+        });
+        binding.layoutHonorCollection.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(HonorCollectionActivity.class);
+        });
+        binding.layoutLittleDoctor.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(LittleDoctorActivity.class);
+        });
+        binding.layoutCleanStorage.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(CleanStorageActivity.class);
+        });
+        binding.layoutPet.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(PetActivity.class);
+        });
+        binding.layoutIncomeAndExpenses.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(IncomeAndExpensesActivity.class);
+        });
+        binding.layoutProperty.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(PropertyActivity.class);
+        });
+        binding.layoutHundredWish.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(HundredWishActivity.class);
+        });
+        binding.layoutCertificateOfHonor.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(CertificateOfHonorActivity.class);
+        });
+        binding.layoutMarriage.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(MarriageActivity.class);
+        });
+        binding.layoutHealthCare.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(HealthCareActivity.class);
+        });
+        binding.layoutPrivacy.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(PrivacyActivity.class);
+        });
+        binding.layoutTourism.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(TourismActivity.class);
+        });
+        binding.layoutContacts.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(ContactsActivity.class);
+        });
+        binding.ivOperate.setOnClickListener(v->{
+            AppManager.getAppManager().startActivity(TestActivity.class);
+        });
+
+        imageCarouselFragment = ImageCarouselFragment.newInstance();
+        videoFragment = VideoFragment.newInstance();
+        replaceFragment(imageCarouselFragment);
+
+        //鍙充笂瑙掓搷浣滃脊绐�
+        mOperatePopupWindow = initPopUpWindow(View.inflate(getSelfActivity(),R.layout.pop_switch_video_or_image,null));
+        mOperatePopupWindow.getContentView().findViewById(R.id.tv_image).setOnClickListener(v -> {
+            mOperatePopupWindow.dismiss();
+            if (imageCarouselFragment == null){
+                imageCarouselFragment = ImageCarouselFragment.newInstance();
             }
+            replaceFragment(imageCarouselFragment);
+
+        });
+        mOperatePopupWindow.getContentView().findViewById(R.id.tv_video).setOnClickListener(v -> {
+            mOperatePopupWindow.dismiss();
+            if (videoFragment == null){
+                videoFragment = VideoFragment.newInstance();
+            }
+            replaceFragment(videoFragment);
+        });
+        //鐐瑰嚮寮瑰嚭鎿嶄綔寮圭獥
+        binding.ivOperate.setOnClickListener(v -> {
+            mOperatePopupWindow.showAsDropDown(binding.ivOperate,-ScreenSizeUtils.dip2px(getSelfActivity(),85) +binding.ivOperate.getWidth(),0);
         });
     }
-
+    public void replaceFragment(Fragment fragment){
+        FragmentTransaction transaction = getSelfActivity().getSupportFragmentManager().beginTransaction();
+        transaction.replace(R.id.layout_frame,fragment);
+        transaction.commit();
+    }
     @Override
     protected void initData() {
-
+        viewModel.getBannerData();
     }
 
     @Override
     protected void initLiveDataObserve() {
-
+        viewModel.getBannerListLiveData().observe(this, new Observer<List<BannerBean>>() {
+            @Override
+            public void onChanged(List<BannerBean> bannerBeans) {
+                List<String> imageList = new ArrayList<>();
+                List<String> videoList = new ArrayList<>();
+                for (BannerBean bannerBean : bannerBeans) {
+                    if (bannerBean.getFlag() == 0){
+                        //鍥剧墖
+                        imageList.add(bannerBean.getUrl());
+                    }else if (bannerBean.getFlag() == 1){
+                        //瑙嗛
+                        videoList.add(bannerBean.getUrl());
+                    }
+                }
+                imageCarouselFragment.setImageList(imageList);
+                videoFragment.setVideoList(videoList);
+            }
+        });
     }
 
     @Override
@@ -88,5 +200,17 @@
         return true;
     }
 
+    @Override
+    protected void dataNull() {
+        super.dataNull();
+        binding.layoutFrame.setVisibility(View.GONE);
+        binding.layoutDataNull.setVisibility(View.VISIBLE);
+    }
 
+    @Override
+    protected void hide() {
+        super.hide();
+        binding.layoutFrame.setVisibility(View.VISIBLE);
+        binding.layoutDataNull.setVisibility(View.GONE);
+    }
 }

--
Gitblit v1.9.1