我被告知最好从主 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>
适配器 ItemRecyclerViewAdapter
,RecyclerView.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/