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

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

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

复制代码
​
public class MediaCreateFragment extends Fragment {
    private FragmentMediaCreateBinding binding;
    private TabLayout tabLayout;

    private ViewPager2 viewPager2;

    private List<TabMediaFragment> tabMediaFragmentList ;
    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        binding = FragmentMediaCreateBinding.inflate(inflater,container,false);
        View root = binding.getRoot();
        initView();
        Log.e("tag","onCreateView中");
        return root;
    }
    private void initView(){



    }

    @Override
    public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);
        tabLayout = binding.tabMediaCreate;
        viewPager2 = binding.viewPager2Tab;
        // 初始化Fragment列表和标题
        tabMediaFragmentList =new ArrayList<>();
        tabMediaFragmentList.add(TabMediaFragment.newInstance("小红书的内容"));
        tabMediaFragmentList.add(TabMediaFragment.newInstance("百家号的内容"));
        tabMediaFragmentList.add(TabMediaFragment.newInstance("今日头条的内容"));
        List<String> titleList = new ArrayList<>();
        titleList.add("小红书");
        titleList.add("百家号");
        titleList.add("今日头条");
        // 获取FragmentManager和Lifecycle实例
        Lifecycle lifecycle = getLifecycle();
        // 创建并设置适配器
        MyFragmentStateAdapter adapter = new MyFragmentStateAdapter(getActivity(), tabMediaFragmentList, titleList);
        // 设置适配器到ViewPager2
        viewPager2.setAdapter(adapter);
        // 设置TabLayout与ViewPager2的关联
        new TabLayoutMediator(tabLayout, viewPager2,
                (tab, position) -> tab.setText(adapter.getPageTitle(position)) // 设置标签标题
        ).attach();
    }

    public class MyFragmentStateAdapter extends FragmentStateAdapter {
        private  List<TabMediaFragment> tabMediaFragmentList;
        private  List<String> titles;
        public MyFragmentStateAdapter(@NonNull FragmentActivity fragmentActivity, List<TabMediaFragment> tabMediaFragmentList, List<String> titles) {
            super(fragmentActivity);
            this.tabMediaFragmentList = tabMediaFragmentList;
            this.titles = titles;
        }
        @NonNull
        @Override
        public Fragment createFragment(int position) {
            return tabMediaFragmentList.get(position);
        }

        @Override
        public int getItemCount() {
            return  tabMediaFragmentList.size();
        }

        public String getPageTitle(int position) {
            return titles.get(position);
        }
    }
}

​

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

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

复制代码
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/frame_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#000">
<TextView
    android:id="@+id/tx_show_content"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:text="测试"
    android:textSize="25sp"
    android:textColor="#000"/>

</FrameLayout>

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

复制代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical">
    <com.google.android.material.tabs.TabLayout
        android:id="@+id/tab_media_create"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:tabGravity="fill"
        app:tabMode="scrollable"
        app:tabIndicatorColor="@color/design_default_color_secondary"
        app:tabIndicatorFullWidth="true"
        app:tabSelectedTextColor="@color/design_default_color_primary"
        app:tabTextColor="@color/purple_200">
    </com.google.android.material.tabs.TabLayout>
    <androidx.viewpager2.widget.ViewPager2
        android:id="@+id/viewPager2_tab"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"/>


</LinearLayout>

包含一个tablayout和viewpager2控件。

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

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

相关推荐
AI袋鼠帝8 小时前
Claude4.5+Gemini3 接管电脑桌面,这回是真无敌了..
人工智能·windows·aigc
獨枭8 小时前
Windows 下安装与使用 Miniconda 完整指南
windows
命里有定数10 小时前
保姆级教程:在 Windows (WSL2) 下本地部署 Qwen3-ASR
windows
lucky670713 小时前
Windows 上彻底卸载 Node.js
windows·node.js
编程小白202613 小时前
从 C++ 基础到效率翻倍:Qt 开发环境搭建与Windows 神级快捷键指南
开发语言·c++·windows·qt·学习
凯子坚持 c15 小时前
CANN 性能剖析实战:从原始事件到交互式火焰图
windows·microsoft
开开心心就好16 小时前
发票合并打印工具,多页布局设置实时预览
linux·运维·服务器·windows·pdf·harmonyos·1024程序员节
獨枭16 小时前
PyCharm 跑通 SAM 全流程实战
windows
仙剑魔尊重楼17 小时前
音乐制作电子软件FL Studio2025.2.4.5242中文版新功能介绍
windows·音频·录屏·音乐·fl studio
PHP小志17 小时前
Windows 服务器怎么修改密码和用户名?账户被系统锁定如何解锁
windows