Я хочу установить TextView текст из списка прослушивания itemView ViewHolder. Я могу вызвать функцию компаньона. но не могу получить доступ к объекту TextView из него - PullRequest
0 голосов
/ 17 января 2019

Я хочу установить TextView text из ClickListener itemView ViewHolder. Я попытался сделать объект-компаньон в классе Activity, и попытался вызвать его из ViewLolders itemView clicklistener. Но внутри объекта-компаньона я не смог получить доступ к объекту TextView в макете

Ниже приведен код адаптера для настройки recyclerview

class QnAdapter(val context: Context, val ques: List<QnoList>):
    RecyclerView.Adapter<QnAdapter.ViewHolder>(){
override fun onCreateViewHolder(p0: ViewGroup, p1: Int): ViewHolder{
    val view = LayoutInflater.from(context).inflate(R.layout.recycler_qno, p0, false)
    return ViewHolder(view)
}
override fun getItemCount(): Int {
    return ques.size
}

override fun onBindViewHolder(p0: ViewHolder, p1: Int){
    val question = ques[p1]
    p0.setData(question, p1)

}

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

    var currentQ: QnoList?=null
    var currentQno: Int =0
    init{
        itemView.setOnClickListener{
            Toast.makeText(context,currentQ!!.qno.toString()+" Selected",Toast.LENGTH_SHORT).show()
            var a1 = MCQActivity
            a1.setText(context)
            a1.setTxt()  // here I want to set TextView, present in Layout of activity(not of recyclerview) text from recyclerview event 


        }

    }
    fun setData(ques:QnoList?,p1:Int){
        itemView.rqno.text = ques!!.qno.toString()
        this.currentQ = ques
        this.currentQno = p1+1
    }
}
}

private fun MCQActivity.Companion.setTxt() {

TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
 }

следующий код класса activity

class MCQActivity : AppCompatActivity() {
companion object {

    fun setText(context: Context){
        Toast.makeText(context, "Hi I am called", Toast.LENGTH_SHORT).show()
    }
}
override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_mcq)

    setRecyclerView()

}

open fun setRecyclerView(){
    val layoutmanager = LinearLayoutManager(this)
    layoutmanager.orientation= LinearLayoutManager.HORIZONTAL
    recycler_qno.layoutManager = layoutmanager
    val adapter = QnAdapter(this, mcq.queslst)
    recycler_qno.adapter = adapter
 }
}

Ответы [ 2 ]

0 голосов
/ 17 января 2019

функция companion аналогична статической функции в Java. В вашем случае вы должны удалить объект-компаньон и сделать функцию setText общедоступной в вашем MCQActivity.

Чтобы получить доступ к своей деятельности с ViewHolder, это просто:

 (itemView.context as? MCQActivity)?.setText("I am handsome")
0 голосов
/ 17 января 2019

Конечно, вы не можете получить доступ к TextView через объект-компаньон.

Сначала вы должны понять определение объекта-компаньона. Это объект, который является общим для всех экземпляров этого класса или любых других классов. похоже на статические поля в Java . Он не имеет ссылок на объекты, созданные для этого класса.

Так как решить вашу проблему?

Поскольку вы уже передали контекст в QnAdapter, и я предполагаю, что это экземпляр / объект MCQActivity, вы можете преобразовать этот контекст в MCQActivity и установить текст для этого экземпляра. Обратитесь к этому коду

class MCQActivity : AppCompatActivity() {
    fun setText(theTextYouWantToSet: String) {
        findViewById<TextView>(R.id.textView).text = theTextYouWantToSet
    }
}

class QnAdapter(val context: Context, val ques: List<String>) : RecyclerView.Adapter<QnAdapter.ViewHolder>() {
    inner class ViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
        init {
            itemView.setOnClickListener {
                (context as MCQActivity).setText("I am handsome")
            }
        }
    }
}
...