Android 万能的RecyclerView适配器(BaseRecyclerViewAdapterHelper)

引用:

implementation "io.github.cymchad:BaseRecyclerViewAdapterHelper4:4.1.2"

BaseQuickAdapter

基本使用:

  • 快速使用

    class TestAdapter : BaseQuickAdapter<Status, TestAdapter.VH>() {
    
        // 自定义ViewHolder类
        class VH(
            parent: ViewGroup,
            val binding: LayoutAnimationBinding = LayoutAnimationBinding.inflate(
                LayoutInflater.from(parent.context), parent, false
            ),
        ) : RecyclerView.ViewHolder(binding.root)
    
        override fun onCreateViewHolder(context: Context, parent: ViewGroup, viewType: Int): VH {
            // 返回一个 ViewHolder
            return VH(parent)
        }
    
        override fun onBindViewHolder(holder: VH, position: Int, item: Status?) {
            // 设置item数据
        }
    
    }
  • 如果Adapter特别简单,可以使用BuickViewHolder

    class TestAdapter : BaseQuickAdapter<Status, QuickViewHolder>() {
    
        override fun onCreateViewHolder(context: Context, parent: ViewGroup, viewType: Int): QuickViewHolder {
            // 返回一个 ViewHolder
            return QuickViewHolder(R.layout.layout_animation, parent)
        }
    
        override fun onBindViewHolder(holder: QuickViewHolder, position: Int, item: Status?) {
            // 设置item数据
            holder.getView(R.id.xxxx)
        }
    
    }

点击事件:

  • item 点击事件

    adapter.setOnItemClickListener { adapter, view, position ->
        Tips.show("onItemClick $position")
    }
    
  • item 长按事件

    adapter.setOnItemLongClickListener { adapter, view, position ->
        Tips.show("onItemLongClick $position")
        true
    }
    
  • item 子控件点击事件

    // 需要传递控件 id
    adapter.addOnItemChildClickListener(R.id.iv_num_add) { adapter, view, position ->
        Tips.show("onItemChildClick:  add $position")
    }
    
  • item 子控件长按事件

    // 需要传递控件 id
    adapter.addOnItemChildLongClickListener(R.id.btn_long) { adapter, view, position ->
        Tips.show("onItemChildLongClick $position")
        true
    }
    

点击事件(扩展)

  • 去除点击抖动(双击)的点击方法。 默认500毫秒间隔,可以传递参数修改。

      // item 去除点击抖动的扩展方法
        adapter.setOnDebouncedItemClick { adapter, view, position ->
            
        }
        // item Child 去除点击抖动的扩展方法
        adapter.addOnDebouncedChildClick { adapter, view, position ->
            
        }

数据操作

  • 设置数据集合

    adapter.submitList(list)
  • 修改某一位置的数据

    //修改index为1处的数据
    adapter[1] = data
  • 新增数据

    // 尾部新增数据
    adapter.add(data)
    
    // 在指定位置添加一条新数据
    adapter.add(1, data)
    
    // 添加数据集
    adapter.addAll(list)
    
    // 指定位置添加数据集
    adapter.addAll(1, list)
  • 删除数据

    // 删除数据
    adapter.remove(data)
    
    // 删除指定位置数据
    adapter.removeAt(1)
  • 交换数据位置(仅仅是这两个数据的位置交换)

    // 交换两个位置的数据
    adapter.swap(1, 3)
  • 移动数据位置(注意和 swap 的区别)

    // 交换两个位置的数据
    adapter.move(1, 3)
  • 获取Item数据的索引

    // 如果返回 -1,表示不存在
    adapter.itemIndexOfFirst(data)
  • 根据索引,获取Item数据

    // 如果返回 null,表示没有数据
    adapter.getItem(1)

动画

  • 内部内置了5种默认动画:

    /**
    * BaseQuickAdapter.AnimationType.AlphaIn
    * BaseQuickAdapter.AnimationType.ScaleIn
    * BaseQuickAdapter.AnimationType.SlideInBottom
    * BaseQuickAdapter.AnimationType.SlideInLeft
    * BaseQuickAdapter.AnimationType.SlideInRight
    */
    adapter.setItemAnimation(BaseQuickAdapter.AnimationType.AlphaIn)
  • 自定义动画 需继承 ItemAnimator 实现自定义动画

    class CustomAnimation1 : ItemAnimator {
        override fun animator(view: View): Animator {
            // 创建三个动画
            val alpha: Animator = ObjectAnimator.ofFloat(view, "alpha", 0f, 1f)
            val scaleY: Animator = ObjectAnimator.ofFloat(view, "scaleY", 1.3f, 1f)
            val scaleX: Animator = ObjectAnimator.ofFloat(view, "scaleX", 1.3f, 1f)
            
            scaleY.interpolator = DecelerateInterpolator()
            scaleX.interpolator = DecelerateInterpolator()
    
            // 多个动画组合,可以使用 AnimatorSet 包装
            val animatorSet = AnimatorSet()
            animatorSet.duration = 350
            animatorSet.play(alpha).with(scaleX).with(scaleY)
            return animatorSet
        }
    }
    
    // 设置动画
    adapter.itemAnimation = CustomAnimation1()
  • 重写动画执行操作

    class TestAdapter : BaseQuickAdapter<Status, QuickViewHolder>() {
    
        ...
    
        override fun startItemAnimator(anim: Animator, holder: RecyclerView.ViewHolder) {
            
        }
    }
  • 是否打开动画

    adapter.animationEnable = true

更多Adapter

更多Adapter
 

项目地址

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
RecyclerViewAndroid 中常用的列表展示控件,它的适配器Adapter)负责将数据绑定到 RecyclerView 上。下面是使用 Android Studio 创建 RecyclerView 适配器的一般步骤: 1. 首先,在布局文件中定义 RecyclerView,例如在 activity_main.xml 文件中添加以下代码: ```xml <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 2. 然后,在适配器类中创建一个继承自 RecyclerView.Adapter 的自定义适配器类,例如 MyAdapter: ```java public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder> { // 定义数据源 private List<String> mData; // 构造方法,传入数据源 public MyAdapter(List<String> data) { mData = data; } // 创建 ViewHolder @Override public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false); return new MyViewHolder(view); } // 绑定 ViewHolder @Override public void onBindViewHolder(MyViewHolder holder, int position) { String item = mData.get(position); holder.textView.setText(item); } // 返回数据源大小 @Override public int getItemCount() { return mData.size(); } // 自定义 ViewHolder public static class MyViewHolder extends RecyclerView.ViewHolder { TextView textView; public MyViewHolder(View itemView) { super(itemView); textView = itemView.findViewById(R.id.text_view); } } } ``` 3. 接下来,在布局文件中定义 RecyclerView 的子项布局,例如在 item_layout.xml 文件中添加一个 TextView: ```xml <TextView android:id="@+id/text_view" android:layout_width="match_parent" android:layout_height="wrap_content" /> ``` 4. 最后,在 Activity 或 Fragment 中设置 RecyclerView适配器,例如在 MainActivity.java 文件中添加以下代码: ```java public class MainActivity extends AppCompatActivity { private RecyclerView mRecyclerView; private MyAdapter mAdapter; private List<String> mData; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 初始化数据源 mData = new ArrayList<>(); mData.add("Item 1"); mData.add("Item 2"); mData.add("Item 3"); // 初始化 RecyclerView mRecyclerView = findViewById(R.id.recyclerView); mRecyclerView.setLayoutManager(new LinearLayoutManager(this)); // 创建适配器并设置给 RecyclerView mAdapter = new MyAdapter(mData); mRecyclerView.setAdapter(mAdapter); } } ``` 这样,一个简单的 RecyclerView 适配器就完成了。你可以根据需要自定义适配器的布局和数据源,并在 onBindViewHolder 方法中绑定数据到 ViewHolder 中的视图上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值