【Android】viewpager和recyclerview联动知识梳理

本文梳理了在Android中实现ViewPager与RecyclerView联动滑动的需求,详细介绍了如何监听和控制两个组件的滑动。针对ViewPager,讨论了FragmentStatePagerAdapter与FragmentPagerAdapter的区别,并指出在滑动监听和页面切换效果处理上的注意事项。对于RecyclerView,阐述了滑动阶段的监听,以及总滑动距离的计算方法。最后,提及其他滚动方法的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近做一个需求,界面上方是一个可滑动切换的viewpager列表,下方是一个用recyclerview做的菜单,recyclerview的item对应viewpager的一页,要求在滑动上面或者下面的时候另一个都要跟着滑动,就好像你执行一次滑动却产生了两个事件序列。

我的思路是分别对viewpager和recyclerview的滑动进行监听,比如viewpager滑动了就计算出他本次滑动到了哪个position,相对于这个position的offset是多少,然后把position和offset传给recyclerview使其滑动到指定的位置。在这个过程中梳理了一下相关的知识点:

1.ViewPager:

FragmentStatePagerAdapter和FragmentPagerAdapter的区别主要在于destroyItem的实现,刚开始的时候我们会给viewpager设置离屏的缓存数量,对于超出缓存范围的fragment,前者会直接从FragmentManager中remove,也就是销毁;而后者只是调用fragment的detach方法销毁视图(这时调用getView返回的是null)。对于本需求这种多页面的来说明显用FragmentPagerAdapter会占用过多内存。

滑动:滑动监听使用addOnPageChangeListener的onPageScrolled回调方法,参数包括页面position和相对这个页面的offset,很方便。如果我们想要翻过一页的话,需要滑动多少距离呢,如果调用了setPageMargin的话,那么就是一页的width+pageMargin。

页面切换效果:如果通过setPageTransformer设置了切换效果,那么在调用scrollTo手动控制viewpager滑动的时候还要处理

介绍:一个基于RecyclerView实现的ViewPager,支持类似于gallary的fling操作。点击上面"下载源码" 按钮,可以下载完整的demo。其中recyclerviewandroid-support中的依赖项目,RecyclerViewPager是主项目。运行效果:使用说明:继承自 RecyclerView.自定义 fling factor.自定义 paging trigger.支持 水平个垂直方向.支持 FragmentViewPager (api 12 )gradlecompile('com.lsjwzh:recyclerviewpager:1.0.2')xml:java:final RecyclerViewPager mRecyclerView = (RecyclerViewPager) this.findViewById(R.id.recyclerViewPager); LinearLayoutManager layout = new LinearLayoutManager(this, LinearLayoutManager.HORIZONTAL,false);//LinearLayoutManager.HORIZONTAL 设置水平滚动 mRecyclerView.setLayoutManager(layout); //set adapter mRecyclerView.setAdapter(new MyRecyclerAdapter());static class MyRecyclerAdapter extends RecyclerView.Adapter { private List items = new ArrayList(); public MyRecyclerAdapter(){ //创建4个页面 for(int i = 1; i<5; i ){ items.add("页面" i); } } public static class ViewHolder extends RecyclerView.ViewHolder{ public ViewHolder(View itemView) { super(itemView); } } @Override public int getItemCount() { // TODO Auto-generated method stub return items.size(); } @Override public void onBindViewHolder(ViewHolder holder, int position) { String item = items.get(position); TextView msgTv = (TextView)holder.itemView.findViewById(R.id.msg); msgTv.setText(item); } @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { if(inflate == null) inflate = (LayoutInflater) parent.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE); View v = (LinearLayout)(inflate.inflate(R.layout.item, null)); return new 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值