前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android学习--RecyclerView

Android学习--RecyclerView

作者头像
Mr.RisingSun
发布2018-01-12 18:16:12
9490
发布2018-01-12 18:16:12
举报
文章被收录于专栏:移动端开发移动端开发

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

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

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

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

代码语言:javascript
复制
/**
 * 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的效果图:

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-07-25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档