RecyclerView;

本文详细介绍了RecyclerView的特性,包括其替代ListView的优势,如自动复用、多种布局支持、动画效果、多布局适应及自定义分割线。文章还深入讲解了RecyclerView的布局设置、依赖导入、适配器使用,并提供了实例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值