【工具类】超级好用简单的RecyclerView适配器,Kotlin打造,链式结构使用

超级好用简单的RecyclerView适配器,Kotlin打造,链式结构使用。
Kotlin,Androidx

项目连接

1.简单使用

构造器 -> 数据 -> 布局 -> 布局设置 -> 创建

Xadapter() -> data() -> layoutId() -> bind() -> create()

    //val rv:RecyclerView 
    rv.adapter = Xadapter<RvDataBean>(this)
                .data(data)
                .layoutId(R.layout.item_rv_text_view)
                .bind { _, holder, _, bean, _ -> holder.setText(R.id.tv, bean.text) }
                .create()
           

在这里插入图片描述

2.不同Item样式的使用

构造器 -> 数据 -> 样式 -> 布局1 -> 布局2 ->… -> build() -> 布局设置1 -> 布局设置2 -> … -> 创建

    //val rv:RecyclerView 
     
    rv.adapter = Xadapter<RvDataBean>(this)
                .data(data)
                .ViewTypeBuider()
                .typeBy { it.type }
                .typeItem(1 to R.layout.item_rv_text_view)
                .typeItem(2 to R.layout.item_rv_text_view2)
                .typeItem(3 to R.layout.item_rv_text_view3)
                .typeItem(R.layout.item_rv_default_view)//默认布局
                .build()
                .bind(1) { _, holder, _, bean, _ -> holder.setText(R.id.tv, bean.text) }
                .bind(2) { _, holder, _, bean, _ -> holder.setText(R.id.tv, bean.text) }
                .bind(3) { _, holder, _, bean, _ -> holder.setText(R.id.tv, bean.text) }
                .bind { _, _, _, _, _ -> }//默认布局
                .create()

在这里插入图片描述

3.使用动画 / 点击事件

    //val rv:RecyclerView 
    rv.adapter = Xadapter<RvDataBean>(this)
                .data(data)
                .layoutId(R.layout.item_rv_text_view)
                .itemAnimation()
                .bind { _, holder, _, bean, _ -> holder.setText(R.id.tv, bean.text) }
                .itemClickListener { _, _, _, bean, _ ->
                    Toast.makeText(this, bean.text, Toast.LENGTH_SHORT).show()
                }
                .create()

4.自定义动画

    .itemAnimation(
        object : ImAnimation {
            //自定义动画
            override fun getAnimators(view: View?): Array<Animator> {
                return super.getAnimators(view)
            }
            //AnModel.NORMAL =普通, AnModel.ONLY_DOWN,AnModel.ONLY_UP  =只有上拉或下拉时才有动画
            override fun getAnModel(): AnModel = AnModel.ONLY_DOWN
            //从第几个开始有动画
            override fun getStart(): Int = 5
        }
    )
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值