From efafbbf142c81c233c71de636a2d3ce9dc2124f0 Mon Sep 17 00:00:00 2001
From: Linjiajia <319408893@qq.com>
Date: 星期二, 12 九月 2023 19:20:05 +0800
Subject: [PATCH] 修复bug

---
 app/src/main/java/com/application/zhangshi_app_android/ui/function/FunctionFragment.java |  103 ++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 97 insertions(+), 6 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 78fe5f2..3d4297a 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
@@ -1,14 +1,27 @@
 package com.application.zhangshi_app_android.ui.function;
 
+import android.content.Intent;
 import android.os.Bundle;
 import android.view.View;
+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.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.home.HomeFragment;
+import com.application.zhangshi_app_android.ui.main.MainActivity;
+
+import java.io.Serializable;
+import java.util.ArrayList;
+import java.util.List;
 
 /**
  * @author Ljj
@@ -16,7 +29,12 @@
  * @desc 鍔熻兘 Fragment
  */
 public class FunctionFragment extends DLBaseFragment<FragmentFunctionBinding,FunctionFragmentViewModel> {
-    public FunctionFragment() {
+
+    private PopupWindow mOperatePopupWindow;
+    private ImageCarouselFragment imageCarouselFragment;
+    private VideoCarouselFragment videoCarouselFragment;
+
+    private FunctionFragment() {
     }
 
     public static FunctionFragment newInstance() {
@@ -42,6 +60,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) {
@@ -105,15 +129,83 @@
         binding.layoutContacts.setOnClickListener(v->{
             AppManager.getAppManager().startActivity(ContactsActivity.class);
         });
+
+        binding.ivOperateSelect.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View v) {
+                AppManager.getAppManager().startActivity(new Intent(getSelfActivity(),ImageSelectActivity.class).putExtra("flag",0).putExtra("list", (Serializable) imageCarouselFragment.getImageList()));
+            }
+        });
+
+        //鍙充笂瑙掓搷浣滃脊绐�
+        mOperatePopupWindow = initPopUpWindow(View.inflate(getSelfActivity(),R.layout.pop_switch_video_or_image,null));
+        mOperatePopupWindow.getContentView().findViewById(R.id.tv_image).setOnClickListener(v -> {
+            mOperatePopupWindow.dismiss();
+            imageCarouselFragment = ImageCarouselFragment.newInstance();
+            replaceFragment(imageCarouselFragment);
+            imageCarouselFragment.setImageList(viewModel.getImageListLiveData().getValue());
+            binding.ivOperateSelect.setOnClickListener(new View.OnClickListener() {
+                @Override
+                public void onClick(View v) {
+                    AppManager.getAppManager().startActivity(new Intent(getSelfActivity(),ImageSelectActivity.class).putExtra("flag",0).putExtra("list", (Serializable) imageCarouselFragment.getImageList()));
+                }
+            });
+        });
+        mOperatePopupWindow.getContentView().findViewById(R.id.tv_video).setOnClickListener(v -> {
+            mOperatePopupWindow.dismiss();
+            videoCarouselFragment = VideoCarouselFragment.newInstance();
+            replaceFragment(videoCarouselFragment);
+            videoCarouselFragment.setVideoList(viewModel.getVideoListLiveData().getValue());
+            binding.ivOperateSelect.setOnClickListener(new View.OnClickListener() {
+                @Override
+                public void onClick(View v) {
+                    AppManager.getAppManager().startActivity(new Intent(getSelfActivity(),ImageSelectActivity.class).putExtra("flag",1).putExtra("list", (Serializable) videoCarouselFragment.getVideoList()));
+                }
+
+            });
+        });
+        //鐐瑰嚮寮瑰嚭鎿嶄綔寮圭獥
+        binding.ivOperate.setOnClickListener(v -> {
+            mOperatePopupWindow.showAsDropDown(binding.ivOperate,-ScreenSizeUtils.dip2px(getSelfActivity(),85) +binding.ivOperate.getWidth(),0);
+        });
+
+        imageCarouselFragment = ImageCarouselFragment.newInstance();
+        replaceFragment(imageCarouselFragment);
+    }
+    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 initData() {
-
+    public void onResume() {
+        super.onResume();
+        initData();
     }
 
     @Override
     protected void initLiveDataObserve() {
+        viewModel.getImageListLiveData().observe(this, new Observer<List<BannerBean>>() {
+            @Override
+            public void onChanged(List<BannerBean> bannerBeans) {
+                if (imageCarouselFragment != null){
+                    imageCarouselFragment.setImageList(bannerBeans);
+                }
+            }
+        });
+        viewModel.getVideoListLiveData().observe(this, new Observer<List<BannerBean>>() {
+            @Override
+            public void onChanged(List<BannerBean> bannerBeans) {
+                if (videoCarouselFragment != null){
+                    videoCarouselFragment.setVideoList(bannerBeans);
+                }
+            }
+        });
 
     }
 
@@ -121,6 +213,5 @@
     protected boolean isStatusBarImmersionEnabled() {
         return true;
     }
-
-
 }
+

--
Gitblit v1.9.1