android - 可能通过 InterationListener 从适配器调用 Intent

标签 android sqlite android-studio kotlin

我被告知最好从主 Activity 启动另一个 Activity 而不是从适配器启动它,我应该使用 InteractionListener 与适配器通信并从主 Activity 调用 Intent 。

问题是我不明白如何实现 InteractionListener。

我试过这个 https://developer.android.com/training/basics/fragments/communicating但我不知道如何初始化回调。

我试着按照别人告诉我的去做,但我是初学者,不理解本教程,遇到了一些我无法解决的错误。

interface OnAdapterInteractionListener {
    fun itemSelected(/Some Parameters Maybe/)
}


class ItemRecyclerViewAdapter(
    private val mListener: OnFragmentInteractionListener?
) :  {
    // set on click listener from item to OnAdapterInteractionListener.itemSelected(/* Maybe Item Argument/)


class MainActivity: Activity(), OnFragmentInteractionListener {
    override fun itemSelected(/ Some Parameters*/ ) {
        startAct....
    }
}

我只想通过点击我的回收站 View 中的一些项目来调用一个 Activity 。

非常感谢您提供的任何帮助或建议。

最佳答案

假设您有一个名称列表(String)并且您希望将它们显示为列表。单击其中一个名称时,您应该在另一个 Activity 中显示显示已单击的项目(名称)。您可以按如下方式实现它。

您的activity_main.xml 文件:

<?xml version="1.0" encoding="utf-8"?>
<androidx.recyclerview.widget.RecyclerView
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/recyclerView"
        tools:context=".MainActivity">

</androidx.recyclerview.widget.RecyclerView>

适配器 ItemRecyclerViewAdapterRecyclerView.Adpater 的子类,它需要 字符串列表 作为构造函数参数并且能够接受 OnAdapterInteractionListener(编辑:放置在adpater内)与activity或fragment交互:

class ItemRecyclerViewAdapter(private val names: List<String>)
    : RecyclerView.Adapter<ItemRecyclerViewAdapter.MyViewHolder>() {

    private var nameClickListener: OnAdapterInteractionListener? = null

    fun setOnAdapterInteractionListener(listener: OnAdapterInteractionListener) {
        nameClickListener = listener
    }

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder {
        val view = LayoutInflater.from(parent.context).inflate(R.layout.item_name, parent, false)

        return MyViewHolder(view)
    }

    override fun getItemCount(): Int {
        return names.size
    }

    override fun onBindViewHolder(holder: MyViewHolder, position: Int) {
        holder.tvName.text = names[position]
    }


    inner class MyViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {

        val tvName: TextView = itemView.findViewById(R.id.tvName)

        init {
            itemView.setOnClickListener {
                nameClickListener?.itemSelected(names[adapterPosition], adapterPosition)
            }
        }
    }

    interface OnAdapterInteractionListener {

        fun itemSelected(name: String, position: Int)
    }
}

MainActivity类:

class MainActivity : AppCompatActivity() {

    private lateinit var mAdapter: ItemRecyclerViewAdapter
    private val names: ArrayList<String> = ArrayList()

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

        recyclerView.layoutManager = LinearLayoutManager(this)
        initNames()
        mAdapter = ItemRecyclerViewAdapter(names)
        mAdapter.setOnAdapterInteractionListener(object : ItemRecyclerViewAdapter.OnAdapterInteractionListener {
            override fun itemSelected(name: String, position: Int) {
                Intent(this@MainActivity, DetailActivity::class.java).also {
                    it.putExtra("name", name)
                    startActivity(it)
                }
            }
        })

        recyclerView.adapter = mAdapter
    }

    private fun initNames() {
        names.add("Name1")
        names.add("Name2")
        names.add("Name3")
    }
}

接下来,您应该实现 DetailActivity 来处理 StringExtra,如下所示,并将其设置为 TextView:

intent?.getStringExtra("name").also {
    detailText.text = it
}

这里的 detailText 是一个 TextView

关于android - 可能通过 InterationListener 从适配器调用 Intent,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56880462/

相关文章:

java - 如何在 Android Studio 中获得全屏 Activity

android - 切换 fragment 时如何保持 subview 的状态?

sqlite - 如果有机会在 Sencha Touch 2 Apps 中使用 SQLite?

Android:更新 sqlite db 从网络服务器下载文件

java - SQLite db 高分表无法正确插入和排序 - Android

Android Studio 的 IntelliJ IDEA SDK/AVD 管理器

java - 如何为Android资源设置固定id

android - Alpha/Beta apk 发布是否适用于 Google Play 中未发布的应用?

安卓模拟器 : Set mobile device number?

android - Android Studio 中的依赖项(来自 Eclipse)多个 Dex 文件