当前位置:   article > 正文

Fragment+Viewpage2+FragmentStateAdapter实现滑动式标签布局

Fragment+Viewpage2+FragmentStateAdapter实现滑动式标签布局

大家好,我是网创有方,今天记录下标签布局的实现方法,先看下效果图。

第一步:编写一个activity或者fragment。内含有一个viewpager2的适配器,适配器类型为FragmentStateAdapter。

  1. public class MediaCreateFragment extends Fragment {
  2. private FragmentMediaCreateBinding binding;
  3. private TabLayout tabLayout;
  4. private ViewPager2 viewPager2;
  5. private List<TabMediaFragment> tabMediaFragmentList ;
  6. @Nullable
  7. @Override
  8. public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
  9. // Inflate the layout for this fragment
  10. binding = FragmentMediaCreateBinding.inflate(inflater,container,false);
  11. View root = binding.getRoot();
  12. initView();
  13. Log.e("tag","onCreateView中");
  14. return root;
  15. }
  16. private void initView(){
  17. }
  18. @Override
  19. public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
  20. super.onViewCreated(view, savedInstanceState);
  21. tabLayout = binding.tabMediaCreate;
  22. viewPager2 = binding.viewPager2Tab;
  23. // 初始化Fragment列表和标题
  24. tabMediaFragmentList =new ArrayList<>();
  25. tabMediaFragmentList.add(TabMediaFragment.newInstance("小红书的内容"));
  26. tabMediaFragmentList.add(TabMediaFragment.newInstance("百家号的内容"));
  27. tabMediaFragmentList.add(TabMediaFragment.newInstance("今日头条的内容"));
  28. List<String> titleList = new ArrayList<>();
  29. titleList.add("小红书");
  30. titleList.add("百家号");
  31. titleList.add("今日头条");
  32. // 获取FragmentManager和Lifecycle实例
  33. Lifecycle lifecycle = getLifecycle();
  34. // 创建并设置适配器
  35. MyFragmentStateAdapter adapter = new MyFragmentStateAdapter(getActivity(), tabMediaFragmentList, titleList);
  36. // 设置适配器到ViewPager2
  37. viewPager2.setAdapter(adapter);
  38. // 设置TabLayout与ViewPager2的关联
  39. new TabLayoutMediator(tabLayout, viewPager2,
  40. (tab, position) -> tab.setText(adapter.getPageTitle(position)) // 设置标签标题
  41. ).attach();
  42. }
  43. public class MyFragmentStateAdapter extends FragmentStateAdapter {
  44. private List<TabMediaFragment> tabMediaFragmentList;
  45. private List<String> titles;
  46. public MyFragmentStateAdapter(@NonNull FragmentActivity fragmentActivity, List<TabMediaFragment> tabMediaFragmentList, List<String> titles) {
  47. super(fragmentActivity);
  48. this.tabMediaFragmentList = tabMediaFragmentList;
  49. this.titles = titles;
  50. }
  51. @NonNull
  52. @Override
  53. public Fragment createFragment(int position) {
  54. return tabMediaFragmentList.get(position);
  55. }
  56. @Override
  57. public int getItemCount() {
  58. return tabMediaFragmentList.size();
  59. }
  60. public String getPageTitle(int position) {
  61. return titles.get(position);
  62. }
  63. }
  64. }

需要包含标签的list和fragment的list

第二步:编写盛载标签页面的容器framelayout

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:id="@+id/frame_layout"
  4. android:layout_width="match_parent"
  5. android:layout_height="match_parent"
  6. android:background="#000">
  7. <TextView
  8. android:id="@+id/tx_show_content"
  9. android:layout_width="wrap_content"
  10. android:layout_height="match_parent"
  11. android:text="测试"
  12. android:textSize="25sp"
  13. android:textColor="#000"/>
  14. </FrameLayout>

第三步:编写activity或者fragment的布局。

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. xmlns:app="http://schemas.android.com/apk/res-auto"
  6. android:orientation="vertical">
  7. <com.google.android.material.tabs.TabLayout
  8. android:id="@+id/tab_media_create"
  9. android:layout_width="match_parent"
  10. android:layout_height="wrap_content"
  11. app:tabGravity="fill"
  12. app:tabMode="scrollable"
  13. app:tabIndicatorColor="@color/design_default_color_secondary"
  14. app:tabIndicatorFullWidth="true"
  15. app:tabSelectedTextColor="@color/design_default_color_primary"
  16. app:tabTextColor="@color/purple_200">
  17. </com.google.android.material.tabs.TabLayout>
  18. <androidx.viewpager2.widget.ViewPager2
  19. android:id="@+id/viewPager2_tab"
  20. android:layout_width="match_parent"
  21. android:layout_height="0dp"
  22. android:layout_weight="1"/>
  23. </LinearLayout>

包含一个tablayout和viewpager2控件。

好了这篇文章到这里就结束了。喜欢的点个关注,收藏。

 网创有方论坛:https://wcyf520.cn,一个专注于网络创业知识分享的论坛。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/一键难忘520/article/detail/778930
推荐阅读
相关标签
  

闽ICP备14008679号