在使用 compose 创建应用程序时,在此处使用的合适 Kotlin Flow 是什么?

问题描述

以下是活动类。

class MainActivity : ComponentActivity() {

    private val viewmodel: Mainviewmodel by viewmodels { MainviewmodelProvider() }

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContent {
            StateExampleTheme {
                // A surface container using the 'background' color from the theme
                Surface(color = MaterialTheme.colors.background) {
                    val state by viewmodel.viewStatePublisher.collectAsstate()

                    when (state) {
                        is ViewState.Failure -> {
                        }
                        ViewState.InProgress -> {
                        }
                        is ViewState.Success -> {
                            val event = (state as ViewState.Success).data
                            Greeting(event,viewmodel)
                        }
                    }
                }
            }
        }
    }
}

@Composable
fun Greeting(event: Event,viewmodel: Mainviewmodel) {
    Column {
        Text(text = "Hello ${event.data}!")
        Button(onClick = {
            viewmodel.updateState(event)
        }) {
            Text(text = "Click")
        }
    }

}

视图模型是

class Mainviewmodel : viewmodel() {
    private val _viewStatePublisher: MutableStateFlow<ViewState> =
        MutableStateFlow(ViewState.Success(Event(0)))
    val viewStatePublisher: StateFlow<ViewState> = _viewStatePublisher

    fun updateState(event: Event) {
        event.data = event.data + 1
        viewmodelScope.launch {
            _viewStatePublisher.emit(ViewState.Success(newEvent))
        }
    }
}

class MainviewmodelProvider : viewmodelProvider.Factory {
    override fun <T : viewmodel?> create(modelClass: Class<T>): T {
        if (modelClass.isAssignableFrom(Mainviewmodel::class.java)) {
            return Mainviewmodel() as T
        }
        throw IllegalArgumentException("UnkNown viewmodel class")
    }
}

我的视图状态由

处理
sealed class ViewState {
    data class Success(val data: Event) : ViewState()
    data class Failure(val message: String) : ViewState()
    object InProgress : ViewState()
}

事件类是

data class Event(var data: Int)

根据上述情况,我无法在单击按钮时更新我的​​用户界面,我需要知道 StateFlow 是否是实现此目的的正确方法

您可以建议将 Event 更改为以下内容

data class Event(val data: Int)

并将 updateState() 方法更新为

fun updateState(event: Event) {
        val newEvent = event.copy(data = event.data + 1)
        viewmodelScope.launch {
            _viewStatePublisher.emit(ViewState.Success(newEvent))
        }
    }

但我希望 datamutable 并在 state 更改时更新 data

谢谢?

解决方法

您尝试做的事情违背了语言设计,StateFlow 可以' t 告知底层数据已更改,因此不会将新数据通知任何订阅者。

我会在数据类中使用 immutable,为什么你需要它是可变的/var?