Android kotlin 实现点击列表item改变颜色(RecyclerView+BRVAH3.0.6+androidx)

一、实现效果

二、引入依赖

appbuild.gradle在添加以下代码
1、implementation 'com.github.CymChad:BaseRecyclerViewAdapterHelper:3.0.6',这个里面带的适配器,直接调用就即可

BaseRecyclerViewAdapterHelper简称BRVAH

Android SDK是否支持BaseRecyclerViewAdapterHelper:3.0.6
android compileSdkVersion 29
android compileSdkVersion 30
android compileSdkVersion 31
android compileSdkVersion 32
android compileSdkVersion 33

这依赖包还需要得到要添加,在Projectbuild.gradle在添加以下代码,不添加就不行

allprojects {
    repositories {
        ...
        maven { url "https://jitpack.io" }//加上
    }
}

四、实现源码

1、适配器

RvAdapter.kt

package com.example.myapplication3.adapter

import com.chad.library.adapter.base.BaseQuickAdapter
import com.chad.library.adapter.base.viewholder.BaseViewHolder
import com.example.myapplication3.R
import kotlinx.android.synthetic.main.item.view.*


class RvAdapter(layoutResId: Int = R.layout.item) :
    BaseQuickAdapter<String, BaseViewHolder>(layoutResId) {

    override fun convert(holder: BaseViewHolder, item: String) {

        if (mCallBack != null) {
            mCallBack!!.convert(holder, holder.layoutPosition);
        }

        holder.itemView.run {
            tv_content.text = item
        }
    }

    //回调
    private var mCallBack: ItemSelectedCallBack? = null

    fun setItemSelectedCallBack(CallBack: ItemSelectedCallBack?) {
        mCallBack = CallBack
    }

    interface ItemSelectedCallBack {
        fun convert(holder: BaseViewHolder?, position: Int)
    }
}

item布局item.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/item_layout"
    android:layout_width="match_parent"
    android:layout_height="50dp"
    android:background="@color/white"
    android:gravity="center">
	<!--<color name="white">#FFFFFFFF</color>-->

    <TextView
        android:id="@+id/tv_content"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="菜单"
        android:textColor="@color/bg"/>
</LinearLayout>

2、实现视图

MainActivity.kt

package com.example.myapplication3

import android.os.Bundle
import android.view.View
import android.widget.LinearLayout
import android.widget.TextView
import androidx.appcompat.app.AppCompatActivity
import androidx.recyclerview.widget.LinearLayoutManager
import com.chad.library.adapter.base.BaseQuickAdapter
import com.chad.library.adapter.base.listener.OnItemClickListener
import com.chad.library.adapter.base.viewholder.BaseViewHolder
import com.example.myapplication3.adapter.RvAdapter
import kotlinx.android.synthetic.main.activity_main.*

class MainActivity : AppCompatActivity(), OnItemClickListener{

    //记录当前位置
    private var currentPosition = 0

    private var mShowItems: MutableList<String> = ArrayList()

    private val mAdapter by lazy {
        RvAdapter().apply {
            setOnItemClickListener(this@MainActivity)
        }
    }

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        init()
    }

    private fun init() {
        for (i in 0..19) {
            mShowItems.add("菜单$i")
        }
        val layoutManager = LinearLayoutManager(this@MainActivity)
        layoutManager.orientation = LinearLayoutManager.VERTICAL
        recyclerView.layoutManager = layoutManager
        recyclerView.adapter = mAdapter
        mAdapter.setList(mShowItems)
//        mAdapter.setItemSelectedCallBack(this)

        mAdapter.setItemSelectedCallBack(object : RvAdapter.ItemSelectedCallBack {
            override fun convert(holder: BaseViewHolder?, position: Int) {

                //初始化组件
                val xx = holder!!.getView<LinearLayout>(R.id.item_layout)
                val xxx = holder!!.getView<TextView>(R.id.tv_content)

                //判断传入的position是否和当前一致
                if (position == currentPosition){
                    xx.setBackgroundColor(resources.getColor(R.color.bg)) //<color name="bg">#E18D12</color>
                    xxx.setTextColor(resources.getColor(R.color.white)) //<color name="white">#FFFFFFFF</color>
                }else{
                    xx.setBackgroundColor(resources.getColor(R.color.white))
                    xxx.setTextColor(resources.getColor(R.color.bg))
                }
            }
        })
    }


    override fun onItemClick(adapter: BaseQuickAdapter<*, *>, view: View, position: Int) {

        //这里赋值
        currentPosition = position
        //每点击一次item就刷新适配器
        mAdapter.notifyDataSetChanged()
    }
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    xmlns:tools="http://schemas.android.com/tools"
    android:orientation="vertical">

    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/recyclerView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        tools:listitem="@layout/item"/>
</LinearLayout>
好的,下面是Kotlin实现的BRVAH和RecyclerView实现无限循环滚动和可点击item的代码: 1. 首先在build.gradle中添加BRVAH依赖: ``` implementation 'com.github.CymChad:BaseRecyclerViewAdapterHelper:3.0.4' ``` 2. 在布局文件中添加RecyclerView: ``` <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 3. 在Activity或Fragment中初始化RecyclerView: ``` val recyclerView = findViewById<RecyclerView>(R.id.recyclerView) val layoutManager = LinearLayoutManager(this) layoutManager.orientation = LinearLayoutManager.HORIZONTAL // 设置为横向滚动 recyclerView.layoutManager = layoutManager ``` 4. 创建Adapter并继承BaseQuickAdapter: ``` class MyAdapter(data: List<String>?) : BaseQuickAdapter<String, BaseViewHolder>(R.layout.item_layout, data) { override fun convert(holder: BaseViewHolder, item: String) { // 设置item的显示内容 holder.setText(R.id.tvItemName, item) } } ``` 5. 创建数据源并初始化Adapter: ``` val dataList = listOf("item1", "item2", "item3", "item4", "item5") val myAdapter = MyAdapter(dataList) recyclerView.adapter = myAdapter ``` 6. 实现无限循环滚动: ``` recyclerView.post { val layoutManager = recyclerView.layoutManager as LinearLayoutManager val firstItem = layoutManager.findFirstVisibleItemPosition() val lastItem = layoutManager.findLastVisibleItemPosition() val itemCount = layoutManager.itemCount // 如果当前第一个可见item是第0个item,则将RecyclerView滚动到最后一个item的位置 if (firstItem == 0) { recyclerView.scrollToPosition(itemCount - 1) } // 如果当前最后一个可见item是最后一个item,则将RecyclerView滚动到第一个item的位置 else if (lastItem == itemCount - 1) { recyclerView.scrollToPosition(0) } } ``` 7. 实现点击item: ``` myAdapter.setOnItemClickListener { adapter, view, position -> // 处理item点击事件 } ``` 以上就是BRVAH和RecyclerView实现无限循环滚动和可点击itemKotlin代码。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

彬sir哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值