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 | 97 ++++++++++++++++++++++++------------------------ 1 files changed, 49 insertions(+), 48 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 41e34d6..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,10 +1,8 @@ package com.application.zhangshi_app_android.ui.function; +import android.content.Intent; 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 androidx.fragment.app.Fragment; @@ -12,19 +10,17 @@ 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.io.Serializable; import java.util.ArrayList; -import java.util.Arrays; import java.util.List; /** @@ -36,7 +32,7 @@ private PopupWindow mOperatePopupWindow; private ImageCarouselFragment imageCarouselFragment; - private VideoFragment videoFragment; + private VideoCarouselFragment videoCarouselFragment; private FunctionFragment() { } @@ -133,35 +129,48 @@ 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); + 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(); - if (imageCarouselFragment == null){ - imageCarouselFragment = ImageCarouselFragment.newInstance(); - } + 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(); - if (videoFragment == null){ - videoFragment = VideoFragment.newInstance(); - } - replaceFragment(videoFragment); + 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(); @@ -174,43 +183,35 @@ } @Override + public void onResume() { + super.onResume(); + initData(); + } + + @Override protected void initLiveDataObserve() { - viewModel.getBannerListLiveData().observe(this, new Observer<List<BannerBean>>() { + viewModel.getImageListLiveData().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()); - } + if (imageCarouselFragment != null){ + imageCarouselFragment.setImageList(bannerBeans); } - imageCarouselFragment.setImageList(imageList); - videoFragment.setVideoList(videoList); } }); + viewModel.getVideoListLiveData().observe(this, new Observer<List<BannerBean>>() { + @Override + public void onChanged(List<BannerBean> bannerBeans) { + if (videoCarouselFragment != null){ + videoCarouselFragment.setVideoList(bannerBeans); + } + } + }); + } @Override protected boolean isStatusBarImmersionEnabled() { 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