IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> BaseQuickAdapter和RecycleView基础使用 -> 正文阅读

[移动开发]BaseQuickAdapter和RecycleView基础使用

相关文章RecycleView实现首页复杂布局效果(横向和竖向)
一.添加依赖
maven { url ‘https://jitpack.io’ }
在这里插入图片描述
implementation ‘com.github.CymChad:BaseRecyclerViewAdapterHelper:3.0.1’
在这里插入图片描述
二.适配器

class BaseAdapter(
    layoutId: Int,//可以传入item的布局
    data: MutableList<InfoBean>? = null//数据
) : BaseQuickAdapter<Bean, BaseViewHolder>(layoutId, data) {
    //重写convert方法
    override fun convert(holder: BaseViewHolder, item: InfoBean?) {
    // 获取当前item的position,这个经常用 viewHolder.getLayoutPosition()
    //可通过getView绑定控件
    val img = holder.getView<ImageView>(R.id.image)
    val text = holder.getView<TextView>(R.id.text)
    text.setText(item?.data)
    //2种方式设置text 1.先绑定再setText 2. helper.setText
        item?.let {
            holder.setText(R.id.name, item?.data)
             .addOnClickListener(R.id.image)    //给子控件添加点击事件
          
                
        }
        //加载图片框架Glide
 //Glide.with(mContext).load(item.url).crossFade().into((Imag//eView) 
   //holder.setImageResource(设置R.id, 设置R.drawable) // 设置图标
    }

}

三.数据类

class InfoBean {
    var url:String?=null
    var image:Int?= 0
    var data:String?=null
}

如果想实现多布局就让数据类实现MultiItemEntity接口同时需要实现getItemType方法,这个方法是用来返回item类型的。

四.主程序

 val recyclerView=findViewById<RecyclerView>(R.layout.Base_recyclerView)
 var dataList = mutableListOf<InfoBean>()
 recyclerView.layoutManager = GridLayoutManager(this,5)
 val adapter=BaseAdapter(R.layout.item,dataList)
 recyclerView.adapter = adapter
        //设置单击事件,其他长按事件也是通过这么设置
        adapter.setOnItemChildClickListener {
                adapter, view, position ->
                    //点击事件处理
                    }
        }

五.布局

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/Base_recyclerView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        tools:ignore="MissingConstraints" 
        app:layoutManager="androidx.recyclerview.widget.GridLayoutManager"
        app:spanCount="5"
        tools:itemCount="6"
        />

</androidx.constraintlayout.widget.ConstraintLayout>

1.可以在XML中设置layoutManager
app:layoutManager=“androidx.recyclerview.widget.GridLayoutManager”
2.app:spanCount=“5”:设置列数为5
3.tools:itemCount=“6”:设置总的item个数
六. MultiItemEntity实现多布局

class Bean(var type: Int, var url: String) : MultiItemEntity {
    override fun getItemType(): Int {
        return type
    }

    companion object {
        const val ITEM1 = 1
        const val ITEM2 = 2
    }

}

class MultiColumnAdapter(data: MutableList<Bean?>?) :
    BaseMultiItemQuickAdapter<MultiItemImgBean?, BaseViewHolder?>(data) {

    init {
        //绑定type和不同布局
        addItemType(MultiItemImgBean.ITEM1, R.layout.item1)
        addItemType(MultiItemImgBean.ITEM2, R.layout.item2)
    }

    override fun convert(helper: BaseViewHolder?, item: Bean?) {
        helper ?: return
        item ?: return
        when (helper.itemViewType) {
            Bean.ITEM1 ->{}
            Bean.ITEM2 -> {}
            else -> {}
        }
    }
}

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-11-29 16:26:00  更:2021-11-29 16:27:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 5:16:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码