我想用来自Firebase的数据填充RecyclerView。我尝试了一些方法,我构建了一个适配器,并尝试填充RecyclerView,但在RecyclerView中没有显示任何数据,我没有得到任何错误。
在firebase控制台中显示查询正在工作,但在模拟器中没有显示任何内容,也没有格尔错误。
[![模拟器中的循环视图][1]][1]
我的布局:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".CamionesActivos">
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/rvCamioness"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginStart="10dp"
android:layout_marginTop="7dp"
android:layout_marginEnd="10dp"
android:layout_marginBottom="7dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
tools:listitem="@layout/tarjeta_recycler" />
</androidx.constraintlayout.widget.ConstraintLay
我的适配器:
class AdaptadorCamiones(private val camionlist:ArrayList<datos>)
:RecyclerView.Adapter<AdaptadorCamiones.MyViewHolder>() {
class MyViewHolder(itemView: View):RecyclerView.ViewHolder(itemView){
val placa :TextView?=itemView.findViewById(R.id.tvPlacaDato)
val peso: TextView?=itemView.findViewById(R.id.tvPesoDato)
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder {
val itemView=
LayoutInflater.from(parent.context).inflate(R.layout.activity_camiones_activos,parent,false)
return MyViewHolder(itemView)
}
override fun onBindViewHolder(holder: MyViewHolder, position: Int) {
holder.placa?.text ?: camionlist[position].Placa
holder.peso?.text ?: camionlist[position].Peso
}
override fun getItemCount(): Int {
return camionlist.size
}
}
我的活动:
class CamionesActivos : AppCompatActivity() {
private lateinit var recyclerView: RecyclerView
private lateinit var camionList: ArrayList<datos>
private var db=Firebase.firestore
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_camiones_activos)
recyclerView=findViewById(R.id.rvCamioness)
recyclerView.layoutManager=LinearLayoutManager(this, LinearLayoutManager.VERTICAL ,false)
camionList= arrayListOf()
recyclerView.adapter = AdaptadorCamiones(camionList)
db=FirebaseFirestore.getInstance()
db.collection("Camiones")
.get()
.addOnSuccessListener {
if(!it.isEmpty){
for (data in it.documents){
val camion: datos? =data.toObject(datos::class.java)
if (camion !=null){
camionList.add(camion)
}
}
}
}
.addOnFailureListener{
Toast.makeText(this, it.toString(), Toast.LENGTH_SHORT).show()
}
}
}```
[1]: https://i.stack.imgur.com/6xmfX.png
1条答案
按热度按时间jdzmm42g1#
数据不显示的原因是因为RecyclerView的适配器(AdaptadorCamiones)不知道它是数据集(camionList)已被更新。每当您将数据插入支持RecyclerView适配器的集合时,您需要通过调用许多通知之一来通知它发生了更改。(...)方法。快速而粗略的解决方案是调用notifyDataSetChanged(),它将触发RecyclerView重新绘制,新数据将位于列表底部。
正确的解决方案是使用适配器的notifyItemInserted(int)重载。此方法将通知适配器在给定位置插入了单个项。适配器将触发RecyclerView以有效地将新项更新到指定位置并以动画形式显示。
调用通知数据集已更改()将强制RecycleView的布局管理器重新绑定所有视图并重新布局所有可见项。除非使用稳定ID,否则RecycleView将不会使用此方法动态显示任何结构更改。使用更具体的notify...重载总是更有效。有一些重载用于通知适配器正在插入多个项,以及用于删除一个或多个项的交互方法。还有一些重载,用于通知适配器项已更新或交换位置。通过调用此重载而不是notifyDataSetChanged(),RecyclerView将能够动态显示结构更改。