Данные из базы данных в реальном времени не будут отображаться на моем ресивере - PullRequest
0 голосов
/ 22 апреля 2019

Мне нужно отобразить данные из базы данных Firebase, используя recyclerView.все работает нормально, я вижу карты и все, но там не будет и данных на карте.

вот мой класс адаптера:

class MyAdapter(c: Context, t: ArrayList<Thoughts>) : RecyclerView.Adapter<MyAdapter.MyViewHolder>() {

var context : Context
    var theThoughts : ArrayList<Thoughts>

    init{
        context = c
        theThoughts = t
    }

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder {
        return MyViewHolder(LayoutInflater.from(context).inflate(R.layout.card_view01, parent, false))
    }//end onCreateViewHolder

    override fun getItemCount(): Int {
        return theThoughts.size
    }//end getItemCount

    override fun onBindViewHolder(holder: MyViewHolder, position: Int) {
        //holder.theTopicAdapter.text[position]
        //holder.theThoughtAdapter.text[position]
        //it works fine withOUT these two lines up
    }//end onBindViewHolder

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

        var theTopicAdapter: TextView
        var theThoughtAdapter: TextView

        init{
            //super.itemView
            theTopicAdapter = itemView.textViewCard01
            theThoughtAdapter = itemView.textViewCard02
        }

        fun MyViewHolder(itemView: View){
            super.itemView
            theTopicAdapter = itemView.textViewCard01
            theThoughtAdapter = itemView.textViewCard02
        }//end MyViewHolder function
        }//end MyViewHolder class
}//end MyAdapter class

это код, где я получаюданные и отобразить его:

databaseReference.addValueEventListener(object: ValueEventListener {
            override fun onDataChange(p0: DataSnapshot) {
                if (p0.exists()){
                    for (thought in p0.children){
                        //var theTopicGetter = thought.child("theTopic").value.toString()
                        val t: Thoughts = thought.getValue(Thoughts::class.java)!!
                        list.add(t)
                    }//end for loop
                }//end if
                adapter = MyAdapter(this@SeePreviousThoughts, list)
                recyclerView.adapter = adapter
            }//end onDataChange
            override fun onCancelled(p0: DatabaseError) {
                Toast.makeText(this@SeePreviousThoughts, "error, please try again.", Toast.LENGTH_SHORT).show()
            }
        })//end the listener

это класс, хотя:

class Thoughts() {
    lateinit var theID: String
    lateinit var theCode: String
    lateinit var theTopic: String
    lateinit var theThought: String

    constructor(theID: String, theCode: String, theTopic: String, theThought: String) : this() {
            this.theID = theID
            this.theCode = theCode
            this.theTopic = theTopic
            this.theThought = theThought
    }

}

Я должен получить данные из базы данных, и они должны отображаться на каждой карточке, но карточкипросто пусто. это скриншот пустого recyclerView слова тема и мысли по умолчанию из файла xml.

Я предполагаю, что моя проблема в том, что функция MyViewHolder в классе MyViewHolder никогда не используется ... снимок экрана с кодом, который не используется

1 Ответ

0 голосов
/ 23 апреля 2019

Проблема была в override fun onBindViewHolder(holder: MyViewHolder, position: Int) методе. Этот адаптер работает:

class MyAdapter(val context: Context, val  theThoughts: ArrayList<Thoughts>) : RecyclerView.Adapter<MyAdapter.MyViewHolder>() {

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder {
        return MyViewHolder(LayoutInflater.from(context).inflate(R.layout.card_view01, parent, false))
    }//end onCreateViewHolder

    override fun getItemCount(): Int {
        return theThoughts.size
    }//end getItemCount

    override fun onBindViewHolder(holder: MyViewHolder, position: Int) {
        holder.theTopicAdapter.text = theThoughts[position].theTopic
        holder.theThoughtAdapter.text = theThoughts[position].theThought
    }//end onBindViewHolder

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

        lateinit var theTopicAdapter: TextView
        lateinit var theThoughtAdapter: TextView

        fun MyViewHolder(itemView: View){
            super.itemView
            theTopicAdapter = itemView.textViewCard01
            theThoughtAdapter = itemView.textViewCard02
        }//end MyViewHolder function
    }//end MyViewHolder class
}//end MyAdapter class 
...