博客
关于我
Android 开发学习进程0.21 tablayout+viewpager+fragment
阅读量:411 次
发布时间:2019-03-06

本文共 2519 字,大约阅读时间需要 8 分钟。

TabLayout + Fragment + ViewPager 的简单使用指南

TabLayout 是 Android 开发中常用的布局组件之一,其结合 Fragment 和 ViewPager 的应用场景也非常广泛。本文将从基础到高级细节,详细介绍如何实现 TabLayout + Fragment + ViewPager 的布局设计。


1. 基本使用方法

要实现 TabLayout + Fragment + ViewPager 的布局,主要需要以下几个步骤:

  • 创建 FragmentPagerAdapter 对象:FragmentPagerAdapter 是 Fragment 的适配器,用于将 Fragment 与 ViewPager 统一起来。在 Android 中,FragmentPagerAdapter 已经是一个比较常用的类,可以直接继承或自定义。

  • 将 Fragment 加入适配器:通过适配器的 setFragment 方法,向适配器中添加 Fragment 实例。这种方式在 Fragment 需要重新渲染数据时非常有用。

  • 设置 ViewPager:将适配器设置到 ViewPager 上,ViewPager 就可以根据 FragmentPagerAdapter 的getItem 方法获取相应的 Fragment。

  • 关联 TabLayout 和 ViewPager:通过 TabLayout 的 setupWithViewPager 方法,将 TabLayout 与 ViewPager 绑定。这样 TabLayout 就可以根据 ViewPager 的页数自动创建 TabItem。


  • 2. 实现细节

    在实现 TabLayout + Fragment + ViewPager 的过程中,需要注意以下几点:

    • Fragment 的销毁机制:FragmentPagerAdapter 默认会缓存 Fragment,建议在 Fragment 需要频繁刷新数据时使用 setFragment 方法来销毁旧 Fragment 并创建新 Fragment。

    • TabLayout 的点击事件:如果需要 TabLayout 的标题栏点击事件,可以通过 setOnTabSelectedListener 方法设置监听器。通常会在监听器中处理 Fragment 的切换逻辑。

    • 自定义 Tab 视图:如果需要更复杂的 Tab Layout 样式,可以通过 FragmentPagerAdapter 的 getCustomView 方法自定义 Tab 视图。这种方法适用于需要在 TabLayout 中嵌入自定义 View 的场景。


    3. 自定义 Tab 视图

    为了实现更个性化的 Tab 视图,可以在 FragmentPagerAdapter 中重写 getCustomView 方法:

    @Overridepublic View getCustomView(int position, TabLayout tabLayout) {    Context context = mContext;    View view = LayoutInflater.from(context).inflate(R.layout.item_tab_act_main, tabLayout, false);    ImageView image = view.findViewById(R.id.im_tab);        switch (position) {        case 0:            image.setBackgroundResource(R.drawable.ic_start);            break;        case 1:            image.setBackgroundResource(R.drawable.ic_start);            break;        case 2:            image.setBackgroundResource(R.drawable.ic_start);            break;    }    return view;}

    通过上述方法,可以为每个 TabItem 设置不同的视图样式。例如,可以为每个 TabItem 设置一个不同的图片或背景色,实现个性化 Tab 样式。


    4. Fragment 之间的跳转

    在 Activity 中,可以通过ViewPager 来实现 Fragment 之间的切换。例如:

    public void setPageCurrent(int position) {    viewPagerAcMain.setCurrentItem(position);}

    这个方法适用于在 Activity 层面上控制 ViewPager 的 Fragment 切换。对于更复杂的场景,可以在 Fragment 中直接调用 FragmentTransaction 来实现 Fragment 之间的跳转。


    5. Fragment 的管理

    FragmentPagerAdapter 提供了几个关键方法来管理 Fragment:

    • getItem(int position):返回对应位置的 Fragment 实例。
    • getCount():返回 Fragment 的总数。
    • setFragment(List
      fragments)
      :用于更新 Fragment 列表,触发 ViewPager 的数据刷新。

    需要注意的是,FragmentPagerAdapter 默认会缓存 Fragment,建议在 Fragment 需要频繁刷新数据时通过 setFragment 方法来销毁旧 Fragment。


    通过以上方法,可以轻松实现 TabLayout + Fragment + ViewPager 的布局设计。这一组件结合的方式在 Android 开发中非常常见,适用于需要多个视图切换的场景。

    转载地址:http://odpkz.baihongyu.com/

    你可能感兴趣的文章
    opencv SVM分类Demo
    查看>>
    OpenCV VideoCapture.get()参数详解
    查看>>
    opencv videocapture读取视频cap.isOpened 输出总是false
    查看>>
    opencv waitKey() 函数理解及应用
    查看>>
    OpenCV 中的图像转换
    查看>>
    OpenCV 人脸识别 C++实例代码
    查看>>
    OpenCV 在 Linux 上的 python 与 anaconda 无法正常工作.收到未实现 cv2.imshow() 的错误
    查看>>
    Opencv 完美配置攻略 2014 (Win8.1 + Opencv 2.4.8 + VS 2013)上
    查看>>
    opencv 模板匹配, 已解决模板过大程序不工作的bug
    查看>>
    OpenCV 错误:(-215)size.width>0 &&函数imshow中的size.height>0
    查看>>
    opencv&Python——多种边缘检测
    查看>>
    opencv&python——高通滤波器和低通滤波器
    查看>>
    OpenCV+Python识别车牌和字符分割的实现
    查看>>
    OpenCV-Python接口、cv和cv2的性能比较
    查看>>
    OpenCV/Python/dlib眨眼检测
    查看>>
    opencv1-加载、修改、保存图像
    查看>>
    opencv10-形态学操作
    查看>>
    opencv11-提取水平直线和垂直直线
    查看>>
    opencv12-图像金字塔
    查看>>
    opencv13-基本阈值操作
    查看>>