不久之前,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);
复制代码
这样竖直轮播图就大功告成了。