我的问题是使用正确的数据触发了Observer<T> { state.value = it }
实时数据观察者,但是compose不会重新组合。仅当我添加一个项目时,所有更改才会传播。如果列表本身已更改,则必须对其进行一些检查。我想它不会比较列表项。
@Composable
fun <R, T : R> LiveData<T>.observeAsState(initial: R): State<R> {
val lifecycleOwner = LifecycleOwnerAmbient.current
val state = remember { mutableStateOf(initial) }
onCommit(this, lifecycleOwner) {
val observer = Observer<T> { state.value = it }
observe(lifecycleOwner, observer)
onDispose { removeObserver(observer) }
}
return state
}
val items: List<TrackedActivityWithMetric> by vm.activities.observeAsState(mutableListOf())
LazyColumnForIndexed(
items = items,
Modifier.padding(8.dp)
) { index, item ->
....
MetricBlock(item.past[1], item.activity.id )
}
答案 0 :(得分:0)
因此,在幕后必须有某种哈希比较机制,以防止两次渲染同一项目(需要更复杂的答案)。错误的渲染是由TrackedActivityWithMetric
数据类构造函数中没有的属性引起的。
答案 1 :(得分:0)
Jetpack Compose 不能很好地与 MutableList 配合使用,您需要使用 List 并执行以下操作:
var myList: List<MyItem> by mutableStateOf(listOf())
private set
用于添加项目:
fun addItem(item: MyItem) {
myList = myList + listOf(myItem)
}
用于编辑项目:
fun editItem(item: MyItem) {
val index = myList.indexOf(myItem)
myList = myList.toMutableList().also {
it[index] = myItem
}
}