Aktivität mit Recyclerview, die Oncreate nicht anrufenAndroid

Forum für diejenigen, die für Android programmieren
Anonymous
 Aktivität mit Recyclerview, die Oncreate nicht anrufen

Post by Anonymous »

Ich versuche, eine Liste mit einer Recycler -Ansicht zu erstellen. Ich habe die Recycler -Ansicht erstellt, einen Adapter und den Adapter mit Standardwerten in OnCreate und später in dieser Funktion eine Firebase -Async -Funktion nenne, die sie richtig bevölkert. Derzeit wird OnCreate nicht einmal angerufen und ich erhalte den Fehler "Kein Adapter angehängt; Überspringen von Layout" < /p>
Chat -Adapterklasse < /p>

Code: Select all

class ChatAdapter(private val messages: List, val conts: Context) : RecyclerView.Adapter() {

val cont = conts

class ChatViewHolder(view: View) : RecyclerView.ViewHolder(view) {
val senderTextView: TextView = view.findViewById(R.id.textViewSender)
val messageTextView: TextView = view.findViewById(R.id.textViewMessage)
val dateTextView: TextView = view.findViewById(R.id.dateTextView)
}

override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ChatViewHolder {
val view = LayoutInflater.from(cont).inflate(R.layout.chat_view_design, parent, false)
return ChatViewHolder(view)
}

@RequiresApi(Build.VERSION_CODES.O)
override fun onBindViewHolder(holder: ChatViewHolder, position: Int) {
val chatMessage = messages[position]
val ref = Firebase.database.reference
ref.child("users").child(chatMessage.fromId).get().addOnCompleteListener { task ->
if (task.isSuccessful) {
val snapshot = task.result
val txt = snapshot.child("username").getValue(String::class.java)
holder.senderTextView.text = txt
}
}
holder.messageTextView.text = chatMessage.text

val instant = Instant.ofEpochMilli((chatMessage.date * 1000).toLong())

val formatter = DateTimeFormatter.ofPattern("MM/dd/yy")
val newDate = Date.from(instant)

val finalDate : LocalDate = newDate.toInstant().atZone(ZoneId.systemDefault()).toLocalDate()

holder.dateTextView.text = formatter.format(finalDate)

if (messages[position].fromId != Firebase.auth.currentUser?.uid) {
holder.senderTextView.setTextColor(Color.parseColor("#FFA500"))
}
}

override fun getItemCount() = messages.size
}

Und schließlich ist hier der Code, der den Adapter nach dem API -Anruf < /p>
festlegt

Code: Select all

    val adapter = ChatAdapter(messages, this)
chatAdapter = adapter
recyclerView.adapter = chatAdapter
recyclerView.scrollToPosition(messages.size - 1)
chatAdapter.notifyDataSetChanged()

Quick Reply

Change Text Case: 
   
  • Similar Topics
    Replies
    Views
    Last post