打造优美列表布局——基础篇

最近学习使用第三方LayoutManager实现了优美的图书列表,记录下我的学习历程,同时写给学弟学习使用。为此我分成了基础和进阶篇,基础篇主要讲利用RecyclerView实现我们的列表展示,主要涉及到的知识是RecyclerView的使用和自定义item点击事件。进阶篇讲解怎么利用开源的LayoutManager实现优美的图书展示页面。

本次的大纲

  • 1.1 RecyclerView的基础使用

    • 1.1.1 RecyclerView的使用之前的配置
    • 1.1.2 RecyclerView的创建
    • 1.1.3 RecyclerView Adapter的使用
    • 1.1.4 LayoutManager的使用
  • 1.2 自定义item点击事件

1.1 RecyclerView的基础使用

1.1.1 RecyclerView的使用之前的配置

RecyclerView是support-v7包的一个列表控件,它相比ListView使用起来更加灵活,RecyclerView支持添加item增加、删除动画,自定义item分割线等等高级功能。
要使用RecyclerView要导入v7包,在build.gradle包添加如下代码

compile 'com.android.support:recyclerview-v7:25.3.0'

1.1.2 RecyclerView的创建

使用RecyclerView很简单,在布局文件里面添加代码

    
    

1.1.3 RecyclerView Adapter的使用

RecyclerView有自己的Adapter,我们创建一个MyRecyclerViewAdapter类来继承RecyclerView.Adapter。
重写所需方法如下

public class MyRecyclerViewAdapter extends RecyclerView.Adapter {

    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        return null;
    }

    @Override
    public void onBindViewHolder(MyViewHolder holder, int position) {

    }

    @Override
    public int getItemCount() {
        return 0;
    }

    class MyViewHolder extends RecyclerView.ViewHolder{

        public MyViewHolder(View itemView) {
            super(itemView);
        }
    }
}
onCreateViewHolder(ViewGroup parent, int viewType) 创建ViewHolder
onBindViewHolder(MyViewHolder holder, int position) 绑定ViewHolder

没有用过RecyclerView或者没有对ListView进行优化处理的可能不知道ViewHolder是什么,简单来说ViewHolder就是一个持有者类,利用ViewHolder把我们item里面的View包装起来,就不需要再像每次BaseAdapter里的getView方法执行的时候绑定每个View的id,实现列表的加载的优化。

我们来完善我们的Adapter,为了简单演示,我们item只包含一个TextView并居中。修改MyRecyclerViewAdapter代码

   public class MyRecyclerViewAdapter extends RecyclerView.Adapter {
       private List mList = new ArrayList<>();
       private Context context;
   
       public MyRecyclerViewAdapter(Context context) {
           this.context = context;
       }
       public void setList(List mList){
           this.mList.addAll(mList);
           notifyDataSetChanged();
       }
   
       @Override
       public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
           MyViewHolder holder = new MyViewHolder(
                   LayoutInflater.from(context).inflate(R.layout.item,parent,false));//创建ViewHolder
           return holder;
       }
   
       @Override
       public void onBindViewHolder(MyViewHolder holder, int position) {
           holder.textView.setText(mList.get(position));//给TextView设置文字
       }
   
       @Override
       public int getItemCount() {
           return mList.size();
       }
   
       class MyViewHolder extends RecyclerView.ViewHolder{
           TextView textView;
   
           public MyViewHolder(final View itemView) {
               super(itemView);
               textView = (TextView) itemView.findViewById(R.id.textView);
           }
       }
   }

1.1.4 LayoutManager的使用

RecyclerView跟listView不一样,listView使用简单但是会有很多限制,而RecyclerView没有太多限制,所以使用起来好多代码需要我们自己定义,就相当于RecyclerView只提供给你一个控件,其他的他什么也不管。
ListView setAdapter 之后就可以使用,RecyclerView需要一个LayoutManager来控制显示列表的样式。在这里我就用普通的线性布局(水平、垂直)来实现列表的排布,下一节演示使用来源LayoutManager实现高雅列表布局。

初始化LayoutManager并设置给RecyclerView

RecyclerView.LayoutManager manager = new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false);
mRecyclerView.setLayoutManager(manager);

LinearLayoutManager 的第二个参数设置水平(HORIZONTAL)与垂直(VERTICAL)。

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mRecyclerView  = (RecyclerView) findViewById(R.id.recyclerView);
        adapter = new MyRecyclerViewAdapter(this);
        list.add("1");
        list.add("2");
        list.add("3");
        list.add("4");
        list.add("5");
        list.add("6");
        adapter.setList(list);
        RecyclerView.LayoutManager manager = new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false);
        mRecyclerView.setLayoutManager(manager);
        mRecyclerView.setAdapter(adapter);
    }

可以看到,连分割线都没有,正如我所说的,RecyclerView不跟你多提供其他东西,RecyclerView的分割线也可以自己定义,这就比listview灵活得多,想要炫酷的效果你就要自己去写代码。

1.2 自定义item点击事件

item的点击事件需要我们自己写接口实现,在Adapter里面添加:

private interface onRecyclerViewOnClickListener{
    void onClick(View view,int position);
}
private onRecyclerViewOnClickListener listener;

public void setOnItemClickListener(onRecyclerViewOnClickListener listener){
    this.listener = listener;
}

我自定义一个onRecyclerViewOnClickListener的接口,提供一个onClick的抽象方法。并且给Adapter添加一个setOnItemClickListener方法。
然后在MyViewHolder里面添加外部点击事件,来处理我们的接口方法。

class MyViewHolder extends RecyclerView.ViewHolder {
    TextView textView;

    public MyViewHolder(final View itemView) {
        super(itemView);
        textView = (TextView) itemView.findViewById(R.id.textView);
        itemView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (listener!=null){
                    listener.onItemClick(itemView,getPosition());
                }
            }
        });
    }
}

在Activity里面调用我们的点击事件

adapter.setOnItemClickListener(new MyRecyclerViewAdapter.onRecyclerViewOnClickListener() {
    @Override
    public void onItemClick(View view, int position) {
        //点击事件的具体处理代码
    }
});

你可能感兴趣的:(打造优美列表布局——基础篇)