RecyclerView的特点:替代listview
- (1)自动复用
- (2)支持3种布局:网格布局+线性布局+瀑布流布局
- (3)支持动画
- (4)支持多布局
- (5)支持自定义分割线
RecyclerView
三种布局格式(下面有图片的展示):
(1)线性(2)网格(3)瀑布
RecyclerView需要手动设置布局样式:
setLayoutManager(new GridLayoutManager(this,2));//网格布局 列数
setLayoutManager(new LinearLayoutManager(this));//线性布局
setLayoutManager(new StaggeredGridLayoutManager(2,StaggeredGridLayoutManager.VERTICAL));//行列数量 瀑布流垂直
首先导入依赖:
implementation ‘com.android.support:recyclerview-v7:28.0.0’
布局类型(不同布局使用的适配器类型不同):
单布局:
多布局:
适配器的使用:
// TODO :多布局时使用(多布局的类型)
@Override
public int getItemViewType(int position) {
return list.get(position).getTepy();
}
// TODO :添加布局(创建ViewHolder)
@NonNull
@Override
public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
//TODO :行布局
if(viewType==0){
View view = LayoutInflater.from(context).inflate(R.layout.item_one, parent, false);
return new LeftMyViewHoulder(view);
}else{
View view = LayoutInflater.from(context).inflate(R.layout.item_two, parent, false);
return new RightMyViewHoulder(view);
}
}
//TODO :绑定数据
@Override
public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, int position) {
if (list.get(position).getTepy()==0){
LeftMyViewHoulder leftMyViewHoulder= (LeftMyViewHoulder) holder;
leftMyViewHoulder.imageView_one.setImageResource(R.mipmap.ic_launcher);
leftMyViewHoulder.textView_one.setText(list.get(position).message);
}else{
RightMyViewHoulder rightMyViewHoulder= (RightMyViewHoulder) holder;
rightMyViewHoulder.imageView_two.setImageResource(R.mipmap.ic_launcher_round);
rightMyViewHoulder.textView_two.setText(list.get(position).message);
}
}
//TODO :绑返回数据个数
@Override
public int getItemCount() {
return list.size();
}
//TODO :布局持有者
class LeftMyViewHoulder extends RecyclerView.ViewHolder{
private ImageView imageView_one;
private TextView textView_one;
public LeftMyViewHoulder(@NonNull View itemView) {
super(itemView);
imageView_one=itemView.findViewById(R.id.item_one_img);
textView_one=itemView.findViewById(R.id.item_one_text);
}
}
//TODO :布局持有者
class RightMyViewHoulder extends RecyclerView.ViewHolder{
private ImageView imageView_two;
private TextView textView_two;
public RightMyViewHoulder(@NonNull View itemView) {
super(itemView);
imageView_two=itemView.findViewById(R.id.item_two_img);
textView_two=itemView.findViewById(R.id.item_two_text);
}
}
设置分割线:
因为作为我们开发者可以设置或者不设置Decoration的。实现一个ItemDecoration,系统提供的ItemDecoration是一个抽象类
//TODO 2:添加分割线(recycler是什么样的分割线就是什么样的)
DividerItemDecoration dividerItemDecoration = new DividerItemDecoration(this,DividerItemDecoration.VERTICAL);
//设置自定义分割线,若不设置有默认
dividerItemDecoration.setDrawable(getDrawable(R.drawable.ic_launcher_background));
rv.addItemDecoration(dividerItemDecoration);
条目的点击事件:
在RecyclerView没有条目的点击事件所以 我们可以通过广播或者接口回调来解决此问题;{
接口回调:
在适配器中获取条目(提供一个set方法,方便在Activity中使用):
在设置数据的时候把条目的下标过去到:
在Activity中调用适配中的接口:
}
设置动画(建议与条目点击事件一起使用):
//TODO 4:设置删除动画
DefaultItemAnimator defaultItemAnimator = new DefaultItemAnimator();//动画
defaultItemAnimator.setRemoveDuration(3000);//在3秒内慢慢的删除掉
rv.setItemAnimator(defaultItemAnimator);