RecyclerView 的使用
2016-05-10 本文已影响603人
满月写
RecyclerView 的使用
RecyclerView
design
RecyclerView的介绍
Demo
已分享到github
,地址:https://github.com/Drolmen/OrmLiteDemo
使用时注意事项
RecyclerView
有两种获取位置的方法,文档是这样说的:
- layout position : Position of an item in the latest layout calculation. This is the position from the LayoutManager's perspective.
- adapter position: Position of an item in the adapter. This is the position from the Adapter's perspective.
这两种方法获取到的位置是相同的,除了adapter.notify*
的时候.后面我们做一下测试。文档主要介绍了position
获取相关的方法和注意事项。
PS:RecyclerView
是强制使用ViewHolder
这种模式的。这点很重要。有很多地方会用到Viewhold
。
RecyclerView 的简单使用
注意,使用RecyclerView
,设置Adapter
之前,必须指定LayoutManager
.
代码如下啊:
---Activity.class:
adapter = new ContractAdapter(this, conctractsTables);
contractRecyclerView.setLayoutManager(new LinearLayoutManager(this));
contractRecyclerView.setAdapter(adapter);
---Adapter.class:
public class ContractAdapter extends RecyclerView.Adapter<ContractAdapter.ContracHolder> {
private LayoutInflater inflater ;
private List<ConctractsTable> datas ;
...构造方法省略去
/**
* 在这个方法里创建View
*/
@Override
public ContracHolder onCreateViewHolder(ViewGroup parent, int viewType) {
return new ContracHolder(inflater.inflate(R.layout.item_for_contract,parent,false));
}
/**
* 在这个方法里绑定数据
*/
@Override
public void onBindViewHolder(ContracHolder holder, int position) {
}
public static class ContracHolder extends RecyclerView.ViewHolder{
private.....
public ContracHolder(View itemView) {
super(itemView);
//初始化holder的成员
......
}
}
RecyclerView 设置分割线
RecyclerView
并没有ListView
直接设置dividerHeight
和dividerColor
的方法,是因为Recycycler
的设计,它只关注如何把View
显示在正确的位置上,视图上的任务,交给了其它的类。
- 首先将
RecyclerView
背景色设置为分割线颜色,设置ItemLayout
背景色为白色 - 自定义
ItemDecoration
,将间距设置为1px
public class DividerItemDecoration extends RecyclerView.ItemDecoration {
@Override
public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
//设置高度为1的间距
outRect.set(0,0,0,1);
}
}
-
RecyclerView
添加ItemDerocation
即可
xxxRecyclerView.addItemDecoration(new DividerItemDecoration());
RecyclerView 设置点击事件
有两种方式:
1. ViewHolder
中设置View的监听事件,并调用viewHolder.getAdapterPosition()
获取position
。修改代码如下:
public static class ContracHolder extends RecyclerView.ViewHolder implements View.OnClickListener{
private...
public ContracHolder(View itemView) {
....
itemView.setOnClickListener(this); //新增
}
@Override
public void onClick(View v) {
Toast.makeText(v.getContext(), "ContracHolder.this.getAdapterPosition():" + getAdapterPosition(), Toast.LENGTH_SHORT).show(); //新增
}
}
2. 设置`RecyclerView`的`OnItemTouchListener`这种模式操作起来比较复杂,方法一即可,此处不做研究了。
RecyclerView 添加headView
和bottomView
大致的思路是这样的:
- 首先,Adapter支持多布局,需要重写
getItemViewType()
和getItemCount()
方法 - 添加
headView、bottomView
的时机,如果RecyclerView
不支持,如何创造这个实际。 - 对
Position
的影响
通过Adapter
或其他方法 获取到的posotion
,不能直接用于数据源中获取数据,可能会出现下表越界。本来想对这个部分做处理,让它返回对于datas
正确的position
,但是后来放弃了。开发者应该知道自己添加什么,必须手动处理这个问题。方法的注释中,给予适当的提示即可。
需要代码的朋友,戳这个链接:https://github.com/Drolmen/OrmLiteDemo
PS:不适合GridView
类型的布局
结束语
纸上学来终觉浅,绝知此事要要身形。这写步骤走下来,收货还是不小的。不仅巩固了关于RecyclerView
的知识,阅读文档的时候,有增多对它的了解,以及锻炼了文档阅读能力。
最后,我问一个Android
开发的朋友一个问题,子啊开发的时候ListView
和RecyclerView
,那个用的更多?他说,不是瀑布流的地方我都用的listview。其实我也有这样的感觉,虽然说低耦合挺吊的, 但是ListView
用起来顺手多了。