看了很多人对RecyclerView的认识,也说下自己项目中所用到的RecyclerView的知识,这篇博文主要是带来RecyclerView的LayoutManager的了解。
对LayoutManager的重写,可以让你实现丰富的RecyclerView,非常灵活。我带来的是一张张卡片层叠的效果,并且可以拖拽删除的。
在重写LayoutManager的时候,必须写generateDefaultLayoutParams()方法,我的理解是,一个界面必须得有一个LayoutParams,代码如下:
@Override
public RecyclerView.LayoutParams generateDefaultLayoutParams() {
return new RecyclerView.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
}
@Override
public void onLayoutChildren(RecyclerView.Recycler recycler, RecyclerView.State state) {
super.onLayoutChildren(recycler, state);
detachAndScrapAttachedViews(recycler);
int itemCount=getItemCount();
if(itemCount<0){
return;
}
for(int i=0;i<itemCount;i++){
View view=recycler.getViewForPosition(i);
addView(view);
measureChildWithMargins(view,0,0);
int width=getDecoratedMeasuredWidth(view);
int height=getDecoratedMeasuredHeight(view);
layoutDecorated(view,getWidth()/2-width/2,getHeight()/2-height/2,getWidth()/2+width/2,getHeight()/2+height/2);
}
}
RecyclerView 中有两个缓存方式,Scrap 和 Recycle。 Scrap 缓存是指里面缓存的View是接下来需要用到的,即里面的数据没有更改。Recycler的缓存的View为里面的数据需要重新绑定,需要通过Adapter重新绑定数据。detachAndScrapAttachedViews 就是对应的Scrap缓存。因为,这个例子的所有子View都是在屏幕上的。。。
for循环就是让所有子View层叠排列的。
所有View层叠排好之后,就需要能够拖拽了,当然,ItemTouchHelper这个类已经帮忙做好了,只需要添加方向上的支持就可以啦~
public SimpleCallBack(RecyclerView rv,RecyclerView.Adapter adapter,List datas){下面就是拖拽的完整代码了
this(0,ItemTouchHelper.DOWN| ItemTouchHelper.UP|ItemTouchHelper.LEFT|ItemTouchHelper.RIGHT,
rv,adapter,datas);
}
//水平方向是否可以被回收掉的阈值好了,已经简单的介绍了RecyclerView的LayoutManager了。写的不好,大家抬举。
public float getThreshold(RecyclerView.ViewHolder viewHolder){
return mRv.getWidth() *getSwipeThreshold(viewHolder);
}
@Override
public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
return false;
}
@Override
public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {
//实现循环的要点
Object remove=mDatas.remove(viewHolder.getLayoutPosition());
mDatas.add(0,remove);
mAdapter.notifyDataSetChanged();
}
@Override
public void onChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) {
super.onChildDraw(c, recyclerView, viewHolder, dX, dY, actionState, isCurrentlyActive);
//这里大家可以自己定义子View的位置了,缩放啊,位移啊等等都可以
}