ViewPager2极简使用

在该模块的build.gradle中添加依赖

implementation 'androidx.viewpager2:viewpager2:1.0.0'

在布局文件中添加ViewPager2控件

<androidx.viewpager2.widget.ViewPager2
    android:id="@+id/vp"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
</androidx.viewpager2.widget.ViewPager2>

在控制器中初始化ViewPager2并展示内容

  • 创建Viewpager2每一页的模板(item_vp_test.xml)

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        android:text="Test"/>

</androidx.constraintlayout.widget.ConstraintLayout>
  • 定义ViewPager2 的适配器(TestVpAdapter)

	public class TestVpAdapter extends RecyclerView.Adapter<TestVpAdapter.TestViewHolder> {

    Context context;

    public TestVpAdapter(Context context){
        this.context = context;
    }

    @NonNull
    @Override
    public TestViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        return new TestViewHolder(LayoutInflater.from(context).inflate(R.layout.item_vp_test, parent, false));
    }

    @Override
    public void onBindViewHolder(@NonNull TestViewHolder holder, int position) {

    }

    @Override
    public int getItemCount() {
        return 10;
    }

    public class TestViewHolder extends RecyclerView.ViewHolder{

        public TestViewHolder(@NonNull View itemView) {
            super(itemView);
        }
    }

}
  • 初始化ViewPager2

    ViewPager2 vp = findViewById(R.id.vp);
    
  • 初始化适配器,并设置给ViewPager2

    vp.setAdapter(new TestVpAdapter(this));
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ViewPager2 可以使用 androidx 库中的 ViewPager2,在 dependencies 中添加 ```Groovy implementation 'androidx.viewpager2:viewpager2:1.0.0' ``` 然后在布局文件中添加 ViewPager2 控件,例如: ```xml <androidx.viewpager2.widget.ViewPager2 android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 接着,在代码中创建 FragmentAdapter,例如: ```Kotlin class MyFragmentAdapter(fragmentManager: FragmentManager, lifecycle: Lifecycle) : FragmentStateAdapter(fragmentManager, lifecycle) { override fun getItemCount(): Int = 3 // Fragment 数量 override fun createFragment(position: Int): Fragment { return when (position) { 0 -> FragmentOne() 1 -> FragmentTwo() 2 -> FragmentThree() else -> throw IndexOutOfBoundsException() } } } ``` 其中,getItemCount 返回 Fragment 数量,createFragment 返回指定位置的 Fragment 对象,例子中返回了三个 FragmentOne、FragmentTwo、FragmentThree。 最后,在 Activity 或 Fragment 中设置 ViewPager2 和 FragmentAdapter,例如: ```Kotlin val viewPager: ViewPager2 = findViewById(R.id.view_pager) val adapter = MyFragmentAdapter(supportFragmentManager, lifecycle) viewPager.adapter = adapter ``` 这样就实现了在 Fragment 之间滑动的功能。 ### 回答2: 要使用ViewPager2在Fragment之间滑动,首先需要在布局文件中定义一个ViewPager2控件,并添加相应的Fragment。 在Activity中,需要先获取ViewPager2控件的实例,并创建一个适配器来管理Fragment的切换。适配器需要继承FragmentStateAdapter,并重写getItemCount()方法和createFragment()方法。 getItemCount()方法返回Fragment的数量。 createFragment()方法根据position返回相应位置的Fragment。 然后,将适配器设置给ViewPager2控件。 接下来,就可以通过手势滑动或者使用setCurrentItem()方法来实现Fragment之间的切换。如果想要禁用滑动,可以使用setUserInputEnabled()方法来设置。 以下是一个单的示例代码: 在布局文件中: ``` <androidx.viewpager2.widget.ViewPager2 android:id="@+id/viewPager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 在Activity中: ```java ViewPager2 viewPager = findViewById(R.id.viewPager); FragmentStateAdapter adapter = new MyAdapter(this); viewPager.setAdapter(adapter); // 实现禁用滑动的功能 // viewPager.setUserInputEnabled(false); // 实现手动切换到指定Fragment的功能 // viewPager.setCurrentItem(2, false); ``` 适配器类: ```java private class MyAdapter extends FragmentStateAdapter { public MyAdapter(FragmentActivity fa) { super(fa); } @Override public int getItemCount() { return 3; // 返回Fragment的数量 } @NonNull @Override public Fragment createFragment(int position) { switch (position) { case 0: return new Fragment1(); case 1: return new Fragment2(); case 2: return new Fragment3(); default: return null; } } } ``` 这样,便可以在ViewPager2中实现Fragment之间的滑动切换了。 ### 回答3: ViewPager2 是 Android Support Library 中的一个组件,用于在多个 fragment 之间进行滑动切换。要在 fragment 之间使用 ViewPager2 进行滑动切换,首先需要进行以下几个步骤: 1. 添加依赖:在项目的 build.gradle 文件中添加以下依赖: ``` implementation 'androidx.viewpager2:viewpager2:1.0.0' ``` 2. 创建 Fragment:创建需要滑动切换的多个 fragment,并在它们的布局文件中添加相应的内容。 3. 创建 ViewPager2:在主 Activity 或者容器 fragment 的布局文件中添加 ViewPager2 组件: ```xml <androidx.viewpager2.widget.ViewPager2 android:id="@+id/viewPager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 4. 创建适配器:创建一个继承自 FragmentStateAdapter 的适配器类,用于管理 fragment 的创建和绑定。在适配器中实现以下两个方法: ```java @Override public int getItemCount() { return fragmentList.size(); } @Override public Fragment createFragment(int position) { return fragmentList.get(position); } ``` 5. 绑定适配器:在主 Activity 或者容器 fragment 的代码中,实例化 ViewPager2,并设置适配器: ```java ViewPager2 viewPager = findViewById(R.id.viewPager); viewPager.setAdapter(new MyAdapter(getSupportFragmentManager(), getLifecycle())); ``` 6. 处理切换事件:可以添加切换事件监听器,监听页面的切换操作,例如: ```java viewPager.registerOnPageChangeCallback(new ViewPager2.OnPageChangeCallback() { @Override public void onPageSelected(int position) { // 处理页面切换事件 } }); ``` 通过以上步骤,就可以在 fragment 之间使用 ViewPager2 进行滑动切换了。根据实际需求,还可以自定义每个 fragment 的布局和显示内容,以及指示器等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值