如何使用 Kotlin 在 RecyclerView 中显示所选项目的项目信息

How to display item info on selected item in RecyclerView using Kotlin

如何在不使用 onClick 方法的情况下显示来自 recyclerview 所选项目的一些信息。当应用程序启动时,第一个项目被选中并突出显示。我需要例如。将 Toast 与数据 class 中的任何值一起使用。我已经实现了 onClick 方法,但问题是如何在不使用此方法的情况下实现它。

这是 MainActivity:

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        
        val exampleList = generateDummyList(20)
        val exampleAdapter = ExampleAdapter(getItem, exampleList)

        exampleAdapter.onItemClick = { item, position: Int ->
            Toast.makeText(this, "Position: $position", Toast.LENGTH_SHORT).show() 
            val intent = Intent(this, ItemActivity::class.java).apply {
                putExtra("itempos", position)
                putExtra("maxSize", maxS)
            }
            startActivity(intent)
        }
    }
}

这是适配器:

class ExampleAdapter(val chosen_item: Int, private val exampleList: List<ExampleItem>):
RecyclerView.Adapter<ExampleAdapter.ExampleViewHolder>()
{
    var onItemClick: ((ExampleItem, Int) -> Unit)? = null    
    var selected_item: Int = chosen_item
    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ExampleViewHolder {
        val itemView = LayoutInflater.from(parent.context).inflate(R.layout.item_recy, parent, false)
        return ExampleViewHolder(itemView)
    }

    override fun onBindViewHolder(holder: ExampleViewHolder, position: Int){
        val currentItem = exampleList[position]
        holder.tv_ID.text = currentItem.id.toString()
        holder.tv_NAME.text = currentItem.name
        holder.tv_EMAIL.text = currentItem.email
        if (position == selected_item){
            holder.tv_NAME.setBackgroundColor(Color.GREEN)            
        } else {
            holder.tv_NAME.setBackgroundColor(Color.TRANSPARENT)            
        } 
}
override fun getItemCount(): Int {
        return exampleList.size
    }
    inner class ExampleViewHolder(itemView:View): RecyclerView.ViewHolder(itemView) {
        val tv_ID: TextView = itemView.tv_ID
        val tv_NAME: TextView = itemView.tv_NAME
        val tv_EMAIL: TextView = itemView.tv_EMAIL
    init {
            itemView.setOnClickListener{
                onItemClick?.invoke(exampleList[absoluteAdapterPosition], absoluteAdapterPosition)
                notifyItemChanged(selected_item)
                selected_item = absoluteAdapterPosition
                notifyItemChanged(selected_item)                
            }            
            itemView.isSelected
        }
    }
}

我有第二个 activity - 当用户点击第一个项目时 activity(recyclerview) - 第二个 activity 是打开的 - 然后我将项目的 ID 提高一个并且首先再次打开 activity,其中突出显示了另一个项目。我需要显示例如。来自 ExampleItem class.

的电子邮件

这是第二个activity:

class ItemActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_item)
        var itempos = intent.getIntExtra("itempos",0)
        val maxSize = intent.getIntExtra("maxSize",0)
        button2.setOnClickListener {
            if (itempos == maxSize){
                itempos = itempos
            } else {
                itempos = itempos + 1
            }
            val intent = Intent(this, MainActivity::class.java).apply {
                putExtra("itemposplus", itempos)
            }
            startActivity(intent)
        }
    }
}

如果我没理解错的话,你想在任何时候(无需点击)获取选中的项目。有几种方法可以做到这一点。我向您推荐在 ViewHolder

中使用 getAdapterPosition() 方法

首先,保存您的 ViewHolder

class ExampleAdapter(val chosen_item: Int, private val exampleList: List<ExampleItem>):
RecyclerView.Adapter<ExampleAdapter.ExampleViewHolder>()
{
    var onItemClick: ((ExampleItem, Int) -> Unit)? = null    
    var selected_item: Int = chosen_item
    lateinit var viewHolder: ExampleViewHolder

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ExampleViewHolder {
        val itemView = LayoutInflater.from(parent.context).inflate(R.layout.item_recy, parent, false)
        viewHolder = ExampleViewHolder(itemView)
        return viewHolder
    }

然后在适配器中写入一个public方法以获取activity

中的当前项
fun getCurrentItem(): ExampleItem = exampleList.get(viewHolder.getAdapterPosition())

终于可以在activity

中获得选中的项目了
val selectedItem = exampleAdapter.getCurrentItem()

您还可以在 RecyclerView

中检查 getLayoutManager().findFirstVisibleItemPosition() 方法