From 99cd5725280d66550aaaaedf8440389fd0d3a60b Mon Sep 17 00:00:00 2001 From: mac <user@users-MacBook-Pro.local> Date: 星期四, 14 十二月 2023 14:24:08 +0800 Subject: [PATCH] 备份一下代码 --- app/src/main/java/com/hdl/photovoltaic/ui/message/MessageFragment.java | 203 ++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 163 insertions(+), 40 deletions(-) diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/message/MessageFragment.java b/app/src/main/java/com/hdl/photovoltaic/ui/message/MessageFragment.java index 5ab25ec..40e921a 100644 --- a/app/src/main/java/com/hdl/photovoltaic/ui/message/MessageFragment.java +++ b/app/src/main/java/com/hdl/photovoltaic/ui/message/MessageFragment.java @@ -1,12 +1,27 @@ package com.hdl.photovoltaic.ui.message; +import android.os.Build; import android.os.Bundle; +import android.os.Handler; import android.view.View; +import androidx.annotation.RequiresApi; +import androidx.fragment.app.Fragment; +import androidx.fragment.app.FragmentManager; +import androidx.fragment.app.FragmentTransaction; + import com.hdl.photovoltaic.R; import com.hdl.photovoltaic.base.CustomBaseFragment; +import com.hdl.photovoltaic.config.ConstantManage; import com.hdl.photovoltaic.databinding.FragmentMessageBinding; +import com.hdl.photovoltaic.other.HdlCommonLogic; +import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus; + +import org.greenrobot.eventbus.EventBus; + +import java.util.ArrayList; +import java.util.List; /** * 娑堟伅 @@ -14,6 +29,16 @@ public class MessageFragment extends CustomBaseFragment { private FragmentMessageBinding viewBinding; + + //褰撳墠鏄剧ず鐨刦ragment + private static final String CURRENT_FRAGMENT = "state_fragment_show"; + private FragmentManager mFragmentManager; + private Fragment currentFragment = new Fragment(); + private List<Fragment> fragments = new ArrayList<>(); + private int currentIndex = 0; + private AllMessageFragment mAllMessageFragment; + private NascentMessageFragment mNascentMessageFragment; + private RecoverMessageFragment mRecoverMessageFragment; @Override public Object getContentView() { @@ -24,6 +49,7 @@ @Override public void onBindView(Bundle savedInstanceState) { + initFragment(savedInstanceState); //鍒濆鍖栫晫闈� initView(); //鍒濆鍖栫洃鍚櫒 @@ -33,6 +59,36 @@ } private void initEvent() { + + //鍙戠敓涓� + viewBinding.messageTabNascentCl.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + viewBinding.messageTabAllTitleTv.setTextColor(getResources().getColor(R.color.text80_FFFFFF, null)); + viewBinding.messageTabNascentTitleTv.setTextColor(getResources().getColor(R.color.text_FFFFFFFF, null)); + viewBinding.messageTabRecoverTitleTv.setTextColor(getResources().getColor(R.color.text80_FFFFFF, null)); + viewBinding.line1V.setVisibility(View.GONE); + viewBinding.line2V.setVisibility(View.VISIBLE); + viewBinding.line3V.setVisibility(View.GONE); + showFragment(0); + postEventBus(HdlCommonLogic.MessageFunctionTabSwitch.nascent); + } + }); + //宸叉仮澶� + viewBinding.messageTabRecoverCl.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + viewBinding.messageTabAllTitleTv.setTextColor(getResources().getColor(R.color.text80_FFFFFF, null)); + viewBinding.messageTabNascentTitleTv.setTextColor(getResources().getColor(R.color.text80_FFFFFF, null)); + viewBinding.messageTabRecoverTitleTv.setTextColor(getResources().getColor(R.color.text_FFFFFFFF, null)); + viewBinding.line1V.setVisibility(View.GONE); + viewBinding.line2V.setVisibility(View.GONE); + viewBinding.line3V.setVisibility(View.VISIBLE); + showFragment(1); + postEventBus(HdlCommonLogic.MessageFunctionTabSwitch.recover); + } + }); + //鍏ㄩ儴 viewBinding.messageTabAllCl.setOnClickListener(new View.OnClickListener() { @Override @@ -43,59 +99,126 @@ viewBinding.line1V.setVisibility(View.VISIBLE); viewBinding.line2V.setVisibility(View.GONE); viewBinding.line3V.setVisibility(View.GONE); - viewBinding.messageAllFcv.setVisibility(View.VISIBLE); - viewBinding.messageNascentFcv.setVisibility(View.GONE); - viewBinding.messageRecoverFcv.setVisibility(View.GONE); + showFragment(2); + postEventBus(HdlCommonLogic.MessageFunctionTabSwitch.all); - } - }); - - viewBinding.messageTabNascentCl.setOnClickListener(new View.OnClickListener() { - @Override - public void onClick(View v) { - viewBinding.messageTabAllTitleTv.setTextColor(getResources().getColor(R.color.text80_FFFFFF, null)); - viewBinding.messageTabNascentTitleTv.setTextColor(getResources().getColor(R.color.text_FFFFFFFF, null)); - viewBinding.messageTabRecoverTitleTv.setTextColor(getResources().getColor(R.color.text80_FFFFFF, null)); - viewBinding.line1V.setVisibility(View.GONE); - viewBinding.line2V.setVisibility(View.VISIBLE); - viewBinding.line3V.setVisibility(View.GONE); - viewBinding.messageAllFcv.setVisibility(View.GONE); - viewBinding.messageNascentFcv.setVisibility(View.VISIBLE); - viewBinding.messageRecoverFcv.setVisibility(View.GONE); - } - }); - - viewBinding.messageTabRecoverCl.setOnClickListener(new View.OnClickListener() { - @Override - public void onClick(View v) { - viewBinding.messageTabAllTitleTv.setTextColor(getResources().getColor(R.color.text80_FFFFFF, null)); - viewBinding.messageTabNascentTitleTv.setTextColor(getResources().getColor(R.color.text80_FFFFFF, null)); - viewBinding.messageTabRecoverTitleTv.setTextColor(getResources().getColor(R.color.text_FFFFFFFF, null)); - viewBinding.line1V.setVisibility(View.GONE); - viewBinding.line2V.setVisibility(View.GONE); - viewBinding.line3V.setVisibility(View.VISIBLE); - viewBinding.messageAllFcv.setVisibility(View.GONE); - viewBinding.messageNascentFcv.setVisibility(View.GONE); - viewBinding.messageRecoverFcv.setVisibility(View.VISIBLE); } }); } private void initView() { - viewBinding.messageTabAllTitleTv.setTextColor(getResources().getColor(R.color.text_FFFFFFFF, null)); - viewBinding.messageTabNascentTitleTv.setTextColor(getResources().getColor(R.color.text80_FFFFFF, null)); + viewBinding.messageTabAllTitleTv.setTextColor(getResources().getColor(R.color.text80_FFFFFF, null)); + viewBinding.messageTabNascentTitleTv.setTextColor(getResources().getColor(R.color.text_FFFFFFFF, null)); viewBinding.messageTabRecoverTitleTv.setTextColor(getResources().getColor(R.color.text80_FFFFFF, null)); - viewBinding.line1V.setVisibility(View.VISIBLE); - viewBinding.line2V.setVisibility(View.GONE); + viewBinding.line1V.setVisibility(View.GONE); + viewBinding.line2V.setVisibility(View.VISIBLE); viewBinding.line3V.setVisibility(View.GONE); - viewBinding.messageAllFcv.setVisibility(View.VISIBLE); - viewBinding.messageNascentFcv.setVisibility(View.GONE); - viewBinding.messageRecoverFcv.setVisibility(View.GONE); + if (this.currentIndex == 0) { + postEventBus(HdlCommonLogic.MessageFunctionTabSwitch.nascent); + } else if (this.currentIndex == 1) { + postEventBus(HdlCommonLogic.MessageFunctionTabSwitch.recover); + } else if (this.currentIndex == 2) { + postEventBus(HdlCommonLogic.MessageFunctionTabSwitch.all); + } } private void initData() { } + /** + * 鍙戝竷鐐瑰嚮浜嬩欢 + * + * @param tabSwitch - + */ + private void postEventBus(HdlCommonLogic.MessageFunctionTabSwitch tabSwitch) { + BaseEventBus baseEventBus = new BaseEventBus(); + baseEventBus.setTopic(ConstantManage.message_function_tab_switch); + baseEventBus.setType(tabSwitch + ""); + EventBus.getDefault().post(baseEventBus); + } + + + /** + * 鍒濆鍖朏ragment + * + * @param savedInstanceState - + */ + private void initFragment(Bundle savedInstanceState) { + mFragmentManager = _mActivity.getSupportFragmentManager(); + //纰庣墖鍐呴渶瑕佷娇鐢ㄦ潈闄愬拰forresult + + mNascentMessageFragment = new NascentMessageFragment(); + mRecoverMessageFragment = new RecoverMessageFragment(); + mAllMessageFragment = new AllMessageFragment(); + if (savedInstanceState != null) { + //鈥滃唴瀛橀噸鍚�濇椂璋冪敤 鑾峰彇鈥滃唴瀛橀噸鍚�濇椂淇濆瓨鐨勭储寮曚笅鏍� + currentIndex = savedInstanceState.getInt(CURRENT_FRAGMENT, 0); + if (fragments.size() != 0) { + fragments.clear(); + } + fragments.add(mFragmentManager.findFragmentByTag(0 + "")); + fragments.add(mFragmentManager.findFragmentByTag(1 + "")); + fragments.add(mFragmentManager.findFragmentByTag(2 + "")); + restoreFragment();//鎭㈠fragment椤甸潰 + } else { + //姝e父鍚姩鏃惰皟鐢� + fragments.add(mAllMessageFragment); + fragments.add(mNascentMessageFragment); + fragments.add(mRecoverMessageFragment); + showFragment(); + + + } + + } + + /** + * 鍒囨崲Fragment + * + * @param index 绱㈠紩 + */ + private void showFragment(int index) { + currentIndex = index; + showFragment(); + } + + /** + * 浣跨敤show() hide()鍒囨崲椤甸潰 + * 鏄剧ずfragment + */ + private void showFragment() { + FragmentTransaction ft = mFragmentManager.beginTransaction(); + //濡傛灉涔嬪墠娌℃湁娣诲姞杩� + if (!fragments.get(currentIndex).isAdded()) { + //绗笁涓弬鏁颁负娣诲姞褰撳墠鐨刦ragment鏃剁粦瀹氫竴涓猼ag + ft.hide(currentFragment) + .add(R.id.message_fcv, fragments.get(currentIndex), "" + currentIndex); + } else { + ft.hide(currentFragment) + .show(fragments.get(currentIndex)); + } + currentFragment = fragments.get(currentIndex); + ft.commit(); + } + + /** + * 鎭㈠fragment + */ + + private void restoreFragment() { + FragmentTransaction ft = mFragmentManager.beginTransaction(); + for (int i = 0; i < fragments.size(); i++) { + if (i == currentIndex) { + ft.show(fragments.get(i)); + } else { + ft.hide(fragments.get(i)); + } + } + ft.commit(); + //鎶婂綋鍓嶆樉绀虹殑fragment璁板綍涓嬫潵 + currentFragment = fragments.get(currentIndex); + } + } -- Gitblit v1.8.0