RecycleView:
是Android L版本中新添加的一个用来取代ListView的SDK,它的灵活性与可替代性比listview更好。
RecyclerView与ListView原理是类似的:
都是仅仅维护少量的View并且可以展示大量的数据集。
RecyclerView:
1、item的排列方式:两种布局管理器:
LinearLayoutManager
GridLayoutManager
2、操作item的时候提供默认的动画效果
3、item多种布局比较方便
4、封装了item的优化
5、适配器不同
不同点:
1、分割线,RecyclerView要自定义设置
2、监听器,RecyclerView没有条目监听器,需要在适配器中自定义
RecyclerView用以下两种方式简化了数据的展示和处理:
使用LayoutManager来确定每一个item的排列方式
为增加和删除项目提供默认的动画效果
也可以定义自己的LayoutManager和添加删除动画
使用RecycleView步骤:
一、添加依赖
//材料设计包
compile 'com.android.support:design:23.4.0'
//cardview包裹item布局,美化效果
compile 'com.android.support:cardview-v7:23.4.0'
//下拉刷新包裹RecyclerView布局
compile 'in.srain.cube:ultra-ptr:1.0.11'
二、相关方法
//如果可以确定每个item的高度是固定的,设置这个选项可以提高性能
recyclerView.setHasFixedSize(true);
//设置item布局之间的分割线,三个选择
recyclerView_main.addItemDecoration(new DividerGridItemDecoration(mContext))
//设置布局管理器
recyclerView.setLayoutManager(LinearLayoutManager、GridLayoutManager)
//设置动画效果
recyclerView.setItemAnimator(new DefaultItemAnimator());
//设置适配器
recyclerView.setAdapter(adapter);
//上拉加载下一页
recyclerView_main.addOnScrollListener(//两个方法:
线性布局管理器得到最后一条item的position;判断,然后页码++)
//置顶功能
recyclerView.scrollToPosition(0);
三、实现下拉刷新:
1、SwipeRefreshLayout:(系统自带的,只是下拉的时候布局并没有被下拉,需要自定义)
//包裹RecyclerView布局
//渐变颜色
swipeRefreshLayout.setColorSchemeColors(...)
//监听刷新
swipeRefreshLayout.setOnRefreshListener(//curPage = 1;loadNetworkData();)
//加载完成,消失图标
swipeRefreshLayout.setRefreshing(false);
2、第三方类库:library_pullToReflect
//布局:PullToRefreshRecyclerView
//用法和RecycleView类似
//如设置布局管理器、设置分割线或者分割空间、set item的高度是固定的
//addOnScrollListener(//几乎很RecycleView一样,下拉刷新)
3、PtrFrameLayout:(需要导包,依赖项)
//布局:PtrFrameLayout包裹RecyclerView
//有两种:
①、旋转圆圈的header(类似SwipeRefreshLayout)
Ⅰ、new一个StoreHouseHeader header,然后设置:
header.setBackgroundColor
header.setTextColor
header.initWithString("LOADING...")
Ⅱ、添加header,ptrFrameLayout.setHeaderView(header);
Ⅲ、绑定UI与刷新状态的监听:ptrFrameLayout.addPtrUIHandler(header);
Ⅳ、添加刷新动作监听:ptrFrameLayout.setPtrHandler(new PtrDefaultHandler)
②、默认的经典header(类似pullTorefresh效果)
Ⅰ 、new一个PtrClassicDefaultHeader
Ⅱ、添加header,ptrFrameLayout.setHeaderView(header);
Ⅲ、绑定UI与刷新状态的监听:ptrFrameLayout.addPtrUIHandler(header);
Ⅳ、添加刷新动作监听:ptrFrameLayout.setPtrHandler(new PtrDefaultHandler)
// 刷新完成,让刷新Loading消失
ptrFrameLayout_main.refreshComplete();
四、RecyclerView的适配器
Ⅰ 、自定义适配器继承 RecyclerView.Adapter<RecyclerView.ViewHolder>
导包正确的化可以简写成Adapter<ViewHolder>
Ⅱ、声明属性,Context 、 数据源 、 LayoutInflater
构造器初始化
Ⅲ、重写方法:
onCreateViewHolder(parent , typeView):填充View,并返回new ViewHolder(view)
onBindViewHolder(holder , position);赋值,并加载图片
getItemId(position)
Ⅳ、ViewHolder内部类 继承 RecyclerView.ViewHolder
声明UI控件,构造器初始化
Ⅴ、重新加载数据:reloadListView(数据源 、 isClear)
Ⅵ、额外的方法:
notifyDataSetChanged()
notifyItemInserted(position)
notifyItemRangeInserted(positionStart, itemCount)
notifyItemRemoved(position)
notifyItemChanged(position)
Ⅶ、如果需要设置单击监听、长按监听
1、interface OnItemClickedListener:两个抽象方法
void onItemClick(int position)
boolean onItemLongClick(int position)
2、声明接口对象:listener、声明RecyclerView对象,并在构造器中传入RecyclerView对象
3、setOnItemClickedListener(接口对象){this.listener = listener}
4、ViewHolder要实现View的单击、长按监听器
5、重写单击监听器
if (listener != null) {
int position = recyclerView.getChildPosition(v)
listener.onItemClick(position)
}
长按监听器:
if (listener != null) {
int position = recyclerView.getChildPosition(v)
return listener.onItemLongClick(position)
}
return false
6、主页就可以调用setOnItemClickedListener(new ...)
附CardView:
<android.support.v7.widget.CardView
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="5dp"
android:elevation="5dp"
app:cardCornerRadius="10dp">
</android.support.v7.widget.CardView>