Android 中 ListView Kotlin 的点击次数
Clicks in ListView Kotlin in the Android
我在 Kotlin 中做了一个 'listView',它显示了一个名称(questoes)和一个列表的位置。单击第一个位置或第二个位置时,我需要转到另一个布局(布局 'activity_e_ex1_port' 的位置 0 和布局 'activity_e_ex2_port' 的位置 1)。但是我在命令 'onCreate' 中的函数 'onCreate' 和结构 'if' 中的 'setContentView' 中有一个错误。
package com.example.asus.aprendecomigovelhinho
import android.content.Context
import android.content.Intent
import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import android.support.v4.content.ContextCompat.startActivity
import android.support.v7.widget.LinearLayoutManager
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.BaseAdapter
import android.widget.ListView
import android.widget.TextView
import kotlinx.android.synthetic.main.activity_d_lista.*
class D_lista : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_d_lista)
val listView = findViewById<ListView>(R.id.listView_CaixaEntrada)
listView.adapter=MyCustomAdpter(this)
}
private class MyCustomAdpter(context: Context): BaseAdapter(){
private val mContext: Context
private val questoes = arrayListOf<String>(
"Português 1º ano", "Português 2º ano")
init {
mContext = context
}
//indicará quantas linhas terá a lista
override fun getCount(): Int {
return questoes.size
}
override fun getItemId(position: Int): Long {
return position.toLong()
}
override fun getItem(position: Int): Any {
return "TEST STRING"
}
//para renderizar cada linha e depois a próxima
override fun getView(position: Int, convertView: View?, viewGroup: ViewGroup?): View {
val layoutInflater = LayoutInflater.from(mContext)
val rowlista = layoutInflater.inflate(R.layout.activity_d_lista_row, viewGroup, false)
val questaoTextView = rowlista.findViewById<TextView>(R.id.textViewQuestão)
questaoTextView.text = questoes.get(position )
val ordem = position+1
val positionTextView = rowlista.findViewById<TextView> (R.id.textViewPosicao)
positionTextView.text = "Ordem de chegada: $ordem"
return rowlista
}
fun onCreate(position: Int, savedInstanceState: Bundle?){
if(position==0) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_e_ex1_port)
}
if(position==1) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_e_ex2_port)
}
}
}
}
您可以使用 RecyclerView
,您可以覆盖 getItemViewType()
以在不同位置使用不同的布局。
要创建 RecyclerView
,请参阅 this and for getItemViewType()
refer this
我在 Kotlin 中做了一个 'listView',它显示了一个名称(questoes)和一个列表的位置。单击第一个位置或第二个位置时,我需要转到另一个布局(布局 'activity_e_ex1_port' 的位置 0 和布局 'activity_e_ex2_port' 的位置 1)。但是我在命令 'onCreate' 中的函数 'onCreate' 和结构 'if' 中的 'setContentView' 中有一个错误。
package com.example.asus.aprendecomigovelhinho
import android.content.Context
import android.content.Intent
import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import android.support.v4.content.ContextCompat.startActivity
import android.support.v7.widget.LinearLayoutManager
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.BaseAdapter
import android.widget.ListView
import android.widget.TextView
import kotlinx.android.synthetic.main.activity_d_lista.*
class D_lista : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_d_lista)
val listView = findViewById<ListView>(R.id.listView_CaixaEntrada)
listView.adapter=MyCustomAdpter(this)
}
private class MyCustomAdpter(context: Context): BaseAdapter(){
private val mContext: Context
private val questoes = arrayListOf<String>(
"Português 1º ano", "Português 2º ano")
init {
mContext = context
}
//indicará quantas linhas terá a lista
override fun getCount(): Int {
return questoes.size
}
override fun getItemId(position: Int): Long {
return position.toLong()
}
override fun getItem(position: Int): Any {
return "TEST STRING"
}
//para renderizar cada linha e depois a próxima
override fun getView(position: Int, convertView: View?, viewGroup: ViewGroup?): View {
val layoutInflater = LayoutInflater.from(mContext)
val rowlista = layoutInflater.inflate(R.layout.activity_d_lista_row, viewGroup, false)
val questaoTextView = rowlista.findViewById<TextView>(R.id.textViewQuestão)
questaoTextView.text = questoes.get(position )
val ordem = position+1
val positionTextView = rowlista.findViewById<TextView> (R.id.textViewPosicao)
positionTextView.text = "Ordem de chegada: $ordem"
return rowlista
}
fun onCreate(position: Int, savedInstanceState: Bundle?){
if(position==0) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_e_ex1_port)
}
if(position==1) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_e_ex2_port)
}
}
}
}
您可以使用 RecyclerView
,您可以覆盖 getItemViewType()
以在不同位置使用不同的布局。
要创建 RecyclerView
,请参阅 this and for getItemViewType()
refer this