Предположим, у вас есть список имен (String
с), и вы хотите показать их в виде списка. При щелчке по одному из этих имен вы должны показать элемент (имя), показанный по нажатию, в другой активности . Вы можете реализовать это следующим образом.
Ваш 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), чтобы взаимодействовать с деятельностью или фрагментом:
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
.