当前位置: 首页 > article >正文

【Android】ViewPager基本用法总结

文章目录

  • 一、添加ViewPager控件
  • 二、构建适配器类
  • 三、在 MainActivity 中设置适配器
    • 示例一:图片切换
      • 适配器
      • MainActivity
    • 示例二:Fragment切换
      • 适配器
      • Fragment
      • MainActivity

ViewPager 是 Android 中一个用于在同一屏幕上滑动不同页面(通常是左右滑动)的组件。它通常用于实现多页面滑动效果,比如应用的引导页、图片轮播、以及支持标签导航的界面。

ViewPagerPagerAdapter 结合使用。PagerAdapter 是一个适配器,它负责为 ViewPager 提供页面内容。每个页面通常是一个 Fragment,也可以是一个普通的 View

特点:

  1. 滑动效果ViewPager 允许用户通过滑动手势在不同页面之间切换。
  2. 缓存页面:默认情况下,ViewPager 会缓存当前页面的前一页和后一页,以提高 滑动性能。
  3. 与TabLayout结合ViewPager 常常与 TabLayout 配合使用,实现顶部标签栏导航。

一、添加ViewPager控件

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <androidx.viewpager.widget.ViewPager
        android:id="@+id/viewPager"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</androidx.constraintlayout.widget.ConstraintLayout>

二、构建适配器类

image-20240904200221023

继承PagerAdapter并实现4个方法:

getCountdestroyIteminstantiateItemisViewFromObject

public class MyViewPagerAdapter extends PagerAdapter {

    @Override
    public int getCount() {
        return 0;
    }

    @Override
    public void destroyItem(@NonNull View container, int position, @NonNull Object object) {
        super.destroyItem(container, position, object);
    }

    @NonNull
    @Override
    public Object instantiateItem(@NonNull View container, int position) {
        return super.instantiateItem(container, position);
    }

    @Override
    public boolean isViewFromObject(@NonNull View view, @NonNull Object object) {
        return false;
    }
}

image-20240904201150661

三、在 MainActivity 中设置适配器

示例一:图片切换

适配器

public class MyViewPagerAdapter extends PagerAdapter {
    List<ImageView> mImageViewList;

    public MyViewPagerAdapter(List<ImageView> mImageViewList) {
        this.mImageViewList = mImageViewList;
    }

    @Override
    public int getCount() {
        return mImageViewList == null ? 0 : mImageViewList.size();
    }


    @Override
    public boolean isViewFromObject(@NonNull View view, @NonNull Object object) {
        return view == object;
    }

    @NonNull
    @Override
    public Object instantiateItem(@NonNull ViewGroup container, int position) {
        container.addView(mImageViewList.get(position));
        return mImageViewList.get(position);
    }

    // 该方法需删除super方法,否则会报错闪退
    @Override
    public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
        container.removeView((View) object);
    }
}

MainActivity

public class MainActivity extends AppCompatActivity {
    private MyViewPagerAdapter myViewPagerAdapter;
    private ViewPager viewPager;
    List<ImageView> imageViewsList;

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        viewPager = findViewById(R.id.viewPager);

        initData();
        myViewPagerAdapter = new MyViewPagerAdapter(imageViewsList);
        viewPager.setAdapter(myViewPagerAdapter);
        viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

            }

            @Override
            public void onPageSelected(int position) {
                Toast.makeText(MainActivity.this, "当前页面为:" + (position + 1), Toast.LENGTH_SHORT).show();
            }

            @Override
            public void onPageScrollStateChanged(int state) {

            }
        });
    }

    private void initData() {
        ImageView imageView1 = new ImageView(this);
        imageView1.setImageResource(R.drawable.p1);
        ImageView imageView2 = new ImageView(this);
        imageView2.setImageResource(R.drawable.p2);
        ImageView imageView3 = new ImageView(this);
        imageView3.setImageResource(R.drawable.p3);

        imageViewsList = new ArrayList<>();
        imageViewsList.add(imageView1);
        imageViewsList.add(imageView2);
        imageViewsList.add(imageView3);
    }
}

Screenrecorder-2024-_-original-original

示例二:Fragment切换

适配器

与图片类似,List存储的为Fragment,并且自定义适配器类继承FragmentPagerAdapter

只用实现两个方法getItemgetCount

public class MyFragmentVPAdapter extends FragmentPagerAdapter {
    List<Fragment> myFragmentList;

    public MyFragmentVPAdapter(@NonNull FragmentManager fm, List<Fragment> fragmentList) {
        super(fm);
        this.myFragmentList = fragmentList;
    }

    @NonNull
    @Override
    public Fragment getItem(int position) {
        return myFragmentList == null ? null : myFragmentList.get(position);
    }

    @Override
    public int getCount() {
        return myFragmentList == null ? 0 : myFragmentList.size();
    }
}

Fragment

这里省略部分代码和fragmentlayout,只放了一个TextView

这里通过param1参数传递信息来设置fragment样式

public class VPFragment extends Fragment {

    private static final String ARG_PARAM1 = "param1";
    private static final String ARG_PARAM2 = "param2";

    private String mParam1;
    private String mParam2;

    private TextView textView;
    
    public static VPFragment newInstance(String param1, String param2) {
        VPFragment fragment = new VPFragment();
        Bundle args = new Bundle();
        args.putString(ARG_PARAM1, param1);
        args.putString(ARG_PARAM2, param2);
        fragment.setArguments(args);
        return fragment;
    }

    @Override
    public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);
        
        textView = view.findViewById(R.id.tv);
        textView.setText(mParam1);
    }
}

MainActivity

public class MainActivity extends AppCompatActivity {
    // 声明 ViewPager 和自定义 Fragment 适配器
    private ViewPager viewPager;
    private MyFragmentVPAdapter mFragmentVPAdapter;
    List<Fragment> mFragmentList; // 存储 Fragment 的列表

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // 绑定布局文件中的 ViewPager 控件
        viewPager = findViewById(R.id.viewPager);

        // 初始化 Fragment 数据
        initData();

        // 创建适配器实例并将其设置给 ViewPager
        mFragmentVPAdapter = new MyFragmentVPAdapter(getSupportFragmentManager(), mFragmentList);
        viewPager.setAdapter(mFragmentVPAdapter);

        // 为 ViewPager 添加页面变化监听器
        viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
                // 当页面正在滑动时调用,可以获取滑动的进度
            }

            @Override
            public void onPageSelected(int position) {
                // 当新页面被选中时调用,显示当前页面索引的 Toast
                Toast.makeText(MainActivity.this, "这是碎片" + (position + 1), Toast.LENGTH_SHORT).show();
            }

            @Override
            public void onPageScrollStateChanged(int state) {
                // 当页面滑动状态改变时调用,比如静止、拖动、自动滑动状态
            }
        });
    }

    // 初始化 Fragment 列表的方法
    private void initData() {
        mFragmentList = new ArrayList<>(); // 创建一个存储 Fragment 的列表

        // 创建并初始化多个 VPFragment 实例,每个 Fragment 对应一个页面
        VPFragment vpFragment1 = VPFragment.newInstance("这是碎片1", "");
        VPFragment vpFragment2 = VPFragment.newInstance("这是碎片2", "");
        VPFragment vpFragment3 = VPFragment.newInstance("这是碎片3", "");

        // 将 Fragment 添加到列表中
        mFragmentList.add(vpFragment1);
        mFragmentList.add(vpFragment2);
        mFragmentList.add(vpFragment3);
    }
}


感谢您的阅读
如有错误烦请指正


参考:

  1. 36.3-ViewPager结合Fragment_哔哩哔哩_bilibili

http://www.kler.cn/a/298866.html

相关文章:

  • Pytorch | 从零构建EfficientNet对CIFAR10进行分类
  • Java代码覆盖率super-jacoco
  • 基于Springboot + vue实现的汽车资讯网站
  • 2、光同步数字传送网的特点
  • 取多个集合的交集
  • 矩阵:Input-Output Interpretation of Matrices (中英双语)
  • 不同工况下的迁移轴承故障诊断,融合SE注意力机制的Resnet18迁移学习,附MATLAB代码...
  • LeetCode53. 最大子数组和(2024秋季每日一题 15)
  • 基于UDP的简易网络通信程序
  • Shell入门
  • Flutter集成Firebase中的Remote Config
  • Ai+若依(集成easyexcel实现excel表格增强)
  • Sky Takeaway
  • WEBSERVER完整体系
  • Java 创建对象方法的演变
  • ARM----时钟
  • Mybatis--SqlSessionFactory 、SqlSession
  • Java并发复习
  • 文案改写工具有哪些?5款智能改写工具迅速提升文案品质
  • Android11 MTK 安装apk时进行密码验证
  • 经验笔记:SQL调优
  • Java 入门指南:Java 并发编程 —— Copy-On-Write 写时复制技术
  • ElasticSearch的DSL查询④(DSL查询、RestClient的DSL查询)
  • Linux内核 -- 内存管理之 lru_cache_add_inactive_or_unevictable 函数
  • go切片的深入学习以及context库的使用
  • 一道迭代器失效练习题