ViewPager2:官方Viewpager升级版来临

不久之前,Android团队推出了一个新的控件:ViewPager2,一看名称就知道这是一个和我们常用的ViewPager功能相似的东西,算是ViewPager的升级版吧。目前还只是推出了第一个预览版:

implementation 'androidx.viewpager2:viewpager2:1.0.0-alpha01'
复制代码

先来看看有哪些改动吧:

新功能:

  • 支持RTL布局
  • 支持竖向滚动
  • 完整支持notifyDataSetChanged

API的变动:

  • FragmentStateAdapter替换了原来的 FragmentStatePagerAdapter
  • RecyclerView.Adapter替换了原来的 PagerAdapter
  • registerOnPageChangeCallback替换了原来的 addPageChangeListener

看了这些,有一点比较吸引人的就是支持竖向滑动了,这是怎么实现的呢?ViewPager2的源码不长,我们来简单分析一下。

简单解析

通过查看源码得知,ViewPager2是直接继承ViewGroup的,意味着和ViewPager不兼容,类注释上也写了它的作用是取代ViewPager,不过短时间内ViewPager应该还不会被废弃掉。

继续查看源码,发现了两个比较重要的成员变量:

    private RecyclerView mRecyclerView;
    private LinearLayoutManager mLayoutManager;
复制代码

所以很清楚得知,ViewPager2的核心实现就是RecyclerView+LinearLayoutManager了,因为LinearLayoutManager本身支持竖向和横向两种方式,所以ViewPager2也能很好地支持这两种滚动方向了。

其实在此之前也不乏有人采用RecyclerView来实现轮播图效果的,这次ViewPager2的出现意味着这种方法终于被扶正了。

为了在手指停止滑动后让页面停留在某一项中间位置,需要设置下SnapHelper:

    new PagerSnapHelper().attachToRecyclerView(mRecyclerView);
复制代码

使用

通过android:orientation来指定滚动方向

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

复制代码

在代码中设置一个普通的RecyclerView.adapter:

   ViewPager2 viewPager2=findViewById(R.id.viewpager2);
        
   RecyclerviewAdapter adapter = new RecyclerviewAdapter(this,data22);
   viewPager2.setAdapter(adapter);
复制代码

这样竖直轮播图就大功告成了。

猜你喜欢

转载自juejin.im/post/5c6e6bb2f265da2de1659dfe
今日推荐