Android开发之RecyclerView的使用全解

本文详细介绍了RecyclerView,它是Android 5.0后推出的新组件,作为ListView的升级版,具备更高的灵活性和扩展性。文章讲解了RecyclerView相较于ListView的优点,如ViewHolder的封装简化了Adapter的编写,以及支持多种布局管理器。同时,文中通过示例展示了如何使用RecyclerView,包括设置布局管理器、Adapter、分隔线、动画以及添加点击事件。此外,还探讨了RecyclerView的ItemDecoration用于定制分隔线,以及如何自定义增删动画。最后,提到了RecyclerView的Item监听事件实现方式。
摘要由CSDN通过智能技术生成

转自

http://blog.csdn.NET/dmk877/article/details/50816933

Android 5.0之后,谷歌公司推出了RecylerView控件,RecylerView,我想看到一个新名词后大部分人会首先发出一个疑问,recylerview是什么?为什么会有recylerview也就是说recylerview的优点是什么?recylerview怎么用?接下来就对这几个问题来一起讨论一下recylerview,如有谬误欢迎批评指正,如有疑问请留言。


通过本篇博客,你将学到以下知识点

①RecyclerView与ListView相比它的优点

②RecyclerView的初步用法

③RecyclerView增加分隔线

④RecyclerView更改分隔线的样式

⑤RecyclerView的Adapter的用法

⑥RecyclerView.Adapter中刷新的几个方法的对比

⑦给RecyclerView增加条目点击事件


1.RecyclerView是什么?

      RecylerView是support-v7包中的新组件,是一个强大的滑动组件,与经典的ListView相比,同样拥有item回收复用的功能,这一点从它的名字recylerview即回收view也可以看出。看到这也许有人会问,不是已经有ListView了吗,为什么还要RecylerView呢?这就牵扯到第二个问题了。


2.RecyclerView的优点是什么?

     根据官方的介绍RecylerView是ListView的升级版,既然如此那RecylerView必然有它的优点,现就RecylerView相对于ListView的优点罗列如下:

①RecylerView封装了viewholder的回收复用,也就是说RecylerView标准化了ViewHolder,编写Adapter面向的是ViewHolder而不再是View了,复用的   逻辑被封装了,写起来更加简单。

②提供了一种插拔式的体验,高度的解耦,异常的灵活,针对一个Item的显示RecylerView专门抽取出了相应的类,来控制Item的显示,使其的扩展性非常强。例如:你想控制横向或者纵向滑动列表效果可以通过LinearLayoutManager这个类来进行控制(与GridView效果对应的是GridLayoutManager,与瀑布流对应的还有StaggeredGridLayoutManager等),也就是说RecylerView不再拘泥于ListView的线性展示方式,它也可以实现GridView的效果等多种效果。你想控制Item的分隔线,可以通过继承RecylerView的ItemDecoration这个类,然后针对自己的业务需求去抒写代码。

③可以控制Item增删的动画,可以通过ItemAnimator这个类进行控制,当然针对增删的动画,RecylerView有其自己默认的实现。

3.RecyclerView的用法

 3.1 RecyclerView的初步用法(包括RecyclerView.Adapter用法)

     说了这么多,可能大家最关心的就是RecylerView应该怎么用,我们先来讨论讨论RecylerView的用法的理论知识,然后结合一个实例来体验一下RecylerView的优势首先我们需要明白的一点是使用RecylerView必须导入support-v7包,在上面我提到过RecylerView高度的解耦,异常的灵活谷歌给我们提供了多个类来控制Item的显示。

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. recyclerView = (RecyclerView) findViewById(R.id.recyclerView);  
  2. LinearLayoutManager layoutManager = new LinearLayoutManager(this );  
  3. //设置布局管理器  
  4. recyclerView.setLayoutManager(layoutManager);  
  5. //设置为垂直布局,这也是默认的  
  6. layoutManager.setOrientation(OrientationHelper. VERTICAL);  
  7. //设置Adapter  
  8. recyclerView.setAdapter( recycleAdapter);  
  9.  //设置分隔线  
  10. recyclerView.addItemDecoration( new DividerGridItemDecoration(this ));  
  11. //设置增加或删除条目的动画  
  12. recyclerView.setItemAnimator( new DefaultItemAnimator());  
可以看到对RecylerView的设置过程,比ListView要复杂一些,这也是RecylerView高度解耦的表现,虽然代码抒写上有点复杂,但它的扩展性是极高的。
在了解了RecyclerView的一些控制之后,紧接着来看看它的Adapter的写法,RecyclerView的Adapter与ListView的Adapter还是有点区别的,RecyclerView.Adapter,需要实现3个方法:
①onCreateViewHolder()
    这个方法主要生成为每个Item inflater出一个View,但是该方法返回的是一个ViewHolder。该方法把View直接封装在ViewHolder中,然后我们面向的是ViewHolder这个实例,当然这个ViewHolder需要我们自己去编写。直接省去了当初的convertView.setTag(holder)和convertView.getTag()这些繁琐的步骤。
②onBindViewHolder()
     这个方法主要用于适配渲染数据到View中。方法提供给你了一个viewHolder,而不是原来的convertView。
③getItemCount()
      这个方法就类似于BaseAdapter的getCount方法了,即总共有多少个条目。
实例:接着来几个小的实例帮助大家更深入的了解RecyclerView的用法,首先来实现一个最简单的列表,效果如下

这种效果的MainAcitivity的代码如下

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. package com.example.reclerviewpractice;  
  2.   
  3. import java.util.ArrayList;  
  4. import java.util.List;  
  5.   
  6. import com.example.reclerviewpractice.adapter.MyRecyclerAdapter;  
  7.   
  8. import android.annotation.SuppressLint;  
  9. import android.os.Bundle;  
  10. import android.support.v7.app.ActionBarActivity;  
  11. import android.support.v7.widget.DefaultItemAnimator;  
  12. import android.support.v7.widget.LinearLayoutManager;  
  13. import android.support.v7.widget.OrientationHelper;  
  14. import android.support.v7.widget.RecyclerView;  
  15.   
  16. public class MainActivity extends ActionBarActivity {  
  17.   
  18.      private RecyclerView recyclerView;  
  19.      private List<String> mDatas;  
  20.      private MyRecyclerAdapter recycleAdapter;  
  21.        
  22.      @SuppressLint("NewApi"@Override  
  23.      protected void onCreate(Bundle savedInstanceState) {  
  24.             super.onCreate(savedInstanceState);  
  25.            setContentView(R.layout. activity_main);  
  26.   
  27.             recyclerView = (RecyclerView) findViewById(R.id.recyclerView );  
  28.              
  29.            initData();  
  30.             recycleAdapter= new MyRecyclerAdapter(MainActivity.this , mDatas );  
  31.            LinearLayoutManager layoutManager = new LinearLayoutManager(this);  
  32.             //设置布局管理器  
  33.             recyclerView.setLayoutManager(layoutManager);  
  34.             //设置为垂直布局,这也是默认的  
  35.            layoutManager.setOrientation(OrientationHelper.VERTICAL);  
  36.             //设置Adapter  
  37.             recyclerView.setAdapter( recycleAdapter);  
  38.             //设置增加或删除条目的动画  
  39.             recyclerView.setItemAnimator(new DefaultItemAnimator());  
  40.              
  41.      }  
  42.   
  43.      private void initData() {  
  44.             mDatas = new ArrayList<String>();  
  45.             for ( int i=0; i < 40; i++) {  
  46.                  mDatas.add( "item"+i);  
  47.            }  
  48.      }  
  49. }  
RecyclerView的Adapter的代码如下:
[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. package com.example.reclerviewpractice.adapter;  
  2.   
  3. import java.util.List;  
  4.   
  5. import com.example.reclerviewpractice.R;  
  6.   
  7. import android.content.Context;  
  8. import android.support.v7.widget.RecyclerView;  
  9. import android.support.v7.widget.RecyclerView.ViewHolder;  
  10. import android.view.LayoutInflater;  
  11. import android.view.View;  
  12. import android.view.ViewGroup;  
  13. import android.widget.TextView;  
  14.   
  15. public class MyRecyclerAdapter extends RecyclerView.Adapter<MyRecyclerAdapter.MyViewHolder> {  
  16.        
  17.      private List<String> mDatas;  
  18.      private Context mContext;  
  19.      private LayoutInflater inflater;  
  20.        
  21.      public MyRecyclerAdapter(Context context, List<String> datas){  
  22.             this. mContext=context;  
  23.             this. mDatas=datas;  
  24.             inflater=LayoutInflater. from(mContext);  
  25.      }  
  26.        
  27.      @Override  
  28.      public int getItemCount() {  
  29.              
  30.             return mDatas.size();  
  31.      }  
  32.   
  33.      //填充onCreateViewHolder方法返回的holder中的控件  
  34.      @Override  
  35.      public void onBindViewHolder(MyViewHolder holder, final int position) {  
  36.              
  37.            holder.tv.setText( mDatas.get(position));  
  38.      }  
  39.   
  40.      //重写onCreateViewHolder方法,返回一个自定义的ViewHolder  
  41.      @Override  
  42.      public
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值