RecyclerView三种常用效果的实现方法-android-kotlin

这篇博客介绍了RecyclerView在Android Kotlin中的应用,包括基本的纵向滚动设置,通过调整LayoutManager实现横向滚动效果,以及如何创建瀑布流布局。还详细说明了如何为RecyclerView的子项添加点击事件。

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

RecyclerView相对于ListView拥有更高的性能和扩展性
不过如果理解了ListView的性能优化,就能对RecyclerView有更深刻的认识
有关ListView的优化,可阅读上一篇博文《ListView的创建和优化》

基本使用方法(纵向滚动)

由于RecyclerView是新增控件,在使用之前需要在app/build.gradle文件中添加其依赖

dependencies {
    //·······略·······
    implementation 'androidx.recyclerview:recyclerview:1.1.0'
}

然后我们修改布局文件,为其添加一个RecyclerView控件

<androidx.recyclerview.widget.RecyclerView
    android:id="@+id/recyclerView"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>

由于RecyclerView并没有内置在系统SDK中,所以需要写出完整的包路径

接着我们为其创建一个适配器

//创建一个适配器,其继承于RecyclerView.Adapter,泛型指定为FruiAdapter.ViewHolder(需要自定义的内部类)
class FruitAdapter(val fruitList:List<Fruit>): RecyclerView.Adapter<FruitAdapter.ViewHolder>() {
   

    //用于缓存控件实例的内部类ViewHolder
    inner class ViewHolder(view:View):RecyclerView.ViewHolder(view){
   
        val fruitImage:ImageView = view.findViewById(R.id.fruitImage)
        val fruitName:TextView = view.findViewById(R.id.fruitName)
    }

    //重写父类的三个方法
    //创建并自动缓存布局
    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
   
        val view = LayoutInflater.from(parent.context).inflate(R.layout.fruit_layout,parent,false)
        return ViewHolder(view)
    }
    //当子项进入屏幕时调用,对子项进行赋值
    override fun onBindViewHolder(holder: ViewHolder, position: Int) {
   
        //获取当前项的元素
        val fruit = fruitList[position]
        //将元素的值赋给当前子项的各个控件
        holder.fruitImage.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值