android - 如何将 FirebaseFirestore 与 Paging 3 库一起使用?
问题描述
我想构建一个像 Twitter 这样的应用程序,我必须在其中显示一个包含实时更新的数据集列表,以便实时计算喜欢和评论。
为此,我正在使用
- RecyclerView - 用于显示可滚动数据列表
- Jetpack LiveData - 用于观察变化并通知观察者。
- Firestore - 作为通过快照更改获取实时数据的后端。
- Paging 3 - 用于将大量数据按块加载到列表中。
但是,我将如何通过向列表发出实时更改来实现具有 PaggingSource 类的 firestore 查询呢?
class FirebasePagingSource() : PagingSource<QuerySnapshot,ItemModel>() {
override fun getRefreshKey(state: PagingState<QuerySnapshot, ItemModel>): QuerySnapshot? {
// Need guidance for implementation
}
override suspend fun load(params: LoadParams<QuerySnapshot>): LoadResult<QuerySnapshot, ItemModel> {
//Need guidance for implementation
} }
这里 ItemModel 是一个数据类
2.ItemListLiveData类
class FirestoreQueryLiveData(private val query: Query)
: LiveData<List<Item>>(), EventListener<QuerySnapshot> {
private lateinit var registration: ListenerRegistration
override fun onActive() {
super.onActive()
registration = query.addSnapshotListener(this)
}
override fun onInactive() {
super.onInactive()
registration.remove()
}
override fun onEvent(snapshot: QuerySnapshot?, error: FirebaseFirestoreException?) {
snapshot?.let {
val documents= mutableListOf<Item>()
for (document in snapshot.documents) {
document.toObject(Item::class.java)?.let {
documents.add(it)
}
}
postValue(documents)
}
} }
解决方案
网上有很多有用的指南。通常,您可以将 Firestore 中的分页数据流设置到 Recycler View 中,然后只需对每个请求进行分页即可。
这可能是一个漫长且复杂的过程,因此我将链接推荐的教程、其来源和相关的 youtube 指南。
推荐阅读
- python - Plotly / Plotly-Dash:如何在图表中为每个图例嵌入数字+增量指标?
- webpack - 如何使用 webpacker 在 Svelte 中包含 Bootstrap 样式
- python - Telegram 通过频道 ID 获取消息
- python - 如何在屏幕上移动包含文本的 Rect?
- c# - 如何在后面的代码中绑定嵌入的图像
- sql - 在 MS Access 中使用 AND & OR 条件自定义查询条件
- swift - 在 Swift 中使用枚举的超类型作为协议或泛型
- pdf - 从雨果网站下载 PDF
- java - Java:Payroll 类的决策结构中的返回语句?
- javascript - 发出一个事件,等待,然后在 Vue 中发出另一个事件