Android学习--RecyclerView

       前面一篇总结了ListView,在这篇我们总结一些这个RecyclerView,我们就从最基本的开始,安卓团队是将RecyclerView定义在support库当中的,因此想要使用RecyclerView这个控件,首先需要在项目的build.gradle中添加相应的依赖库才行。

      下面是添加RecyclerView的相应库:(这里的v7:26.0.0-alphal按照自己相应的版本添加)   

 

 

      添加完后记得点击一下 Sysnc Now 来同步一下

      它的基本的创建和添加到XML文件中我们就不在提了,这个比较简单,先看看要是想实现和前面我们写的ListView相同的效果,下面是最重要的适配器里面的代码,注释就是理解的思路,我们选择通篇复制:

     

/**
 * Created by skotc on 2017/7/18.
 */
// 定义FruitAdapter类,这个类是继承自RecyclerView.Adapter
// public abstract static class Adapter<VH extends ViewHolder> 这句是我们看到的官方的关于Adapter的代码
// 从这句代码中你可以捕捉到的信息就是它的参数 VH 是一个继承自 ViewHolder 的,这也就是我们写ViewHolder必要   
    
public class FruitAdapter extends  RecyclerView.Adapter<FruitAdapter.ViewHolder> {

     //定义一个集合,用来接收这个FruitAdapter初始化之后传进来的数据 因为我们对数据的处理都是在这里进行
     //包括对控件的赋值和告诉这个RecyclerView我们一共有多少条数据
     private List<Fruit> mFruitList;

     //定义一个公共类ViewHolder是继承自RecyclerView.ViewHolder
     public  class  ViewHolder extends RecyclerView.ViewHolder{

          //由于它是继承自RecyclerView.ViewHolder,所以我们再初始化的时候是需要传入一个参数View
          //这个View能帮助我们获取到RecyclerView子项我们定义的控件,所以我们在这里定义了下面两个控件,同样是用来接收他们
          //接收的主要目的是在我们下面的方法里面给他们赋值
          ImageView fruitImage;
          TextView  fruitText;

          // 为了点击事件定义的View
          View fruitView;
          // 这个ViewHolder类型的初始化以及参数和前面我们写的Adapter的道理相同,多看官方源码理解!
          public ViewHolder(View view){

               super(view);
               // 这个我们自定义的fruitView接收view,这个View的参数就是RecyclerView子项的最外层的布局,我们可以在它上面就点击事件
               fruitView = view;
               // 这里就是获取两个控件
               fruitImage = (ImageView) view.findViewById(R.id.fruit_image);
               fruitText  = (TextView)  view.findViewById(R.id.fruit_name);
           }
     }

    //我们定义的FruitAdapter类的构造方法
    public  FruitAdapter(List<Fruit> fruitList ){

        mFruitList = fruitList;
    }

    //由于我们定义的FruitAdapter是继承RecyclerView.Adapter
    //所以下面三个方法我们都要重写
    @Override
    public ViewHolder onCreateViewHolder ( ViewGroup parent , int viewType){

         // 获取fruit_item的布局View
         View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.fruit_item,parent,false);

         // 再用这个View来初始化我们定义的ViewHolder类
         final ViewHolder hoider = new ViewHolder(view);

         // 点击事件
         hoider.fruitView.setOnClickListener(new View.OnClickListener(){

            @Override
            public void onClick(View v){

                int position = hoider.getAdapterPosition();
                Fruit fruit  = mFruitList.get(position);
                Toast.makeText(v.getContext(),"you clicked view " + fruit.getName(),Toast.LENGTH_SHORT).show();
            }
         });
         return  hoider;
    }

    // 下面参数传入的ViewHolder类型的实例holder,就是我们前面方法onCreateViewHolder返回的类型实例
    // 这个实例就是通过fruit_item布局实例化的,ViewHolder里面的控件接收了它们,所以我们就可以利用ViewHolder的控件实例进行赋值操作
    @Override
    public void onBindViewHolder(ViewHolder holder , int position){

        Fruit fruit = mFruitList.get(position);
        holder.fruitImage.setImageResource(fruit.getImageId());
        holder.fruitText.setText(fruit.getName());
    }

    // 这个方法就是前面我们提到的告诉RecyclerView我们有多少个子项
    @Override
    public  int getItemCount(){

        return mFruitList.size();
    }
}

 

      上面就是最重要的代码了,下面就是我们MainActy的代码,我们把这个RecyclerView让它横着滑动,看看我们活动里面的代码,最后我们再看看这整个效果运行起来的效果:

 

 

看看这整个Demo的效果图:

 

 

  

posted @ 2017-07-25 17:38  MrRisingSun  阅读(383)  评论(0编辑  收藏  举报