最近学习使用第三方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很简单,在布局文件里面添加代码
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerView"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
1.1.3 RecyclerView Adapter的使用
RecyclerView有自己的Adapter,我们创建一个MyRecyclerViewAdapter类来继承RecyclerView.Adapter。
重写所需方法如下
public class MyRecyclerViewAdapter extends RecyclerView.Adapter<MyRecyclerViewAdapter.MyViewHolder> {
@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<MyRecyclerViewAdapter.MyViewHolder> {
private List<String> mList = new ArrayList<>();
private Context context;
public MyRecyclerViewAdapter(Context context) {
this.context = context;
}
public void setList(List<String> 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) {
//点击事件的具体处理代码
}
});