欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android如何使用ViewPager2实现页面滑动切换效果

程序员文章站 2022-11-05 15:11:19
目录1.引言2.实现页面滑动切换2.1 引入viewpager2库2.2 使用viewpager22.3 构建fragment2.4 继承fragmentstateadapter2.5 将viewpa...

1.引言

在很多应用中,我们经常会看到多个页面之间滑动切换的场景,viewpager2是viewpager的升级版,本文将简要介绍如何使用viewpager2、fragmentstateadapter和fragment来实现页面之间的滑动切换。

2.实现页面滑动切换

2.1 引入viewpager2库

要使用viewpager2,需要引入viewpager2库,引入方法如下:

implementation "androidx.viewpager2:viewpager2:1.0.0"

2.2 使用viewpager2

在布局中使用viewpager2,示例如下:

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

2.3 构建fragment

本fragment只为简单演示使用,其布局如下:

<linearlayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center"
    android:orientation="vertical">

    <textview
        android:id="@+id/tv_content"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textsize="18sp"
        android:textcolor="@color/black"/>

</linearlayout>

contentfragment类的实现如下:

public class contentfragment extends fragment {
    private string content;

    public contentfragment(string content) {
        this.content = content;
    }

    private textview tv_content;

    @nullable
    @override
    public view oncreateview(@nonnull layoutinflater inflater, @nullable viewgroup container, @nullable bundle savedinstancestate) {
        view view = inflater.inflate(r.layout.fragment_content, container, false);
        tv_content = view.findviewbyid(r.id.tv_content);
        tv_content.settext(content);
        return view;
    }

    public void setcontent(string content) {
        this.content = content;
        tv_content.settext(content);
    }
}

2.4 继承fragmentstateadapter

创建自定义的类contentpageradapter,让它继承fragmentstateadapter,并实现createfragment(int position)和getitemcount()方法,示例如下:

public class contentpageradapter extends fragmentstateadapter {
    private list<contentfragment> datas;

    public contentpageradapter(@nonnull fragmentactivity fragmentactivity,list<contentfragment> datas) {
        super(fragmentactivity);
        this.datas = datas;
    }

    @nonnull
    @override
    public fragment createfragment(int position) {
        return datas.get(position);
    }

    @override
    public int getitemcount() {
        return datas.size();
    }
}

2.5 将viewpager2与适配器绑定

将viewpager2与适配器绑定后,便可实现页面滑动切换,示例如下:

datas = new arraylist<>();
datas.add(new contentfragment("页面1"));
datas.add(new contentfragment("页面2"));
datas.add(new contentfragment("页面3"));
datas.add(new contentfragment("页面4"));
datas.add(new contentfragment("页面5"));
contentpageradapter = new contentpageradapter(this, datas);
viewpager2.setadapter(contentpageradapter);

2.6 垂直方向滑动切换

viewpager2不仅支持水平方向的滑动,还支持垂直方向的滑动,实现垂直滑动也是相当简单,在布局文件中添加android:orientation="vertical"属性即可,如下所示:

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

或者在代码中调用viewpager2的setorientation(viewpager2.orientation_vertical)方法也可以让viewpager2实现垂直方向的滑动。

2.7 fragment更新

当fragment集合发生变化需要更新时,使用fragmentstateadapter进行更新也很便捷,由于viewpager2是基于recyclerview实现的,所以更新数据的时候可以调用notifyitemchanged(int position)、notifyiteminserted(int position)等方法进行更新。

3.总结

使用viewpager2、fragmentstateadapter和fragment可以便捷地实现页面之间的滑动切换,它不仅支持水平方向的滑动,还能通过简单的设置就能实现垂直方向的滑动,灵活地运用viewpager2能实现实际的需求。

到此这篇关于android如何使用viewpager2实现页面滑动切换效果的文章就介绍到这了,更多相关android viewpager2页面滑动切换内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!