android 多个viewmodel之间通信

多个viewmodel之间的通信有多种方法,比如通过resposity将sharedviewmodel作为参数传递,进而完成数据通信,也可以通过一个公共的全局变量进行数据传递。本文中提供一个以singleton单例的方式进行。

1.创建单例的resposity类。

Kotlin 复制代码
class testResposity private constructor(){

    //创建单例
    companion object{
        private var INSTANCE:testResposity?=null
        @Synchronized
        fun getInstance():testResposity{
            if(INSTANCE==null)
                INSTANCE = testResposity()
            return INSTANCE!!
        }
    }

    //以下为业务逻辑
    val data = MutableStateFlow<String>("")
    val _counter1 = MutableStateFlow<Int>(0)
    val counter1 = _counter1.asStateFlow()
    fun updateCounter1()
    {
        _counter1.value++
        if(_counter1.value==2)
        {
            data.value = "second"
        }
        else if(_counter1.value == 3)
        {
            data.value = "third"
        }
    }
}

2.创建测试的viewmodel1

Kotlin 复制代码
class TestViewModel1:ViewModel() {
    //获取resposity单例
    private val resposity = testResposity.getInstance()
    val data = resposity.data

    //调用测试逻辑
    public fun updateCounter1(){
        resposity.updateCounter1()
    }
}

3.按照相同的方式,创建测试的viewmodel2

Kotlin 复制代码
class TestViewModel2:ViewModel() {
    private val resposity = testResposity.getInstance()
    val counter = resposity.counter1
    public fun updateCounter(){
        resposity.updateCounter1()
    }
}

4.测试的compose

Kotlin 复制代码
@Composable
fun TestViewModelScreen(modifier: Modifier = Modifier,
                        viewModel:TestViewModel1,
                        viewModel2:TestViewModel2,
                        onClicked:()->Unit,
                        onClicked2:()->Unit
                        ) {

    val counter1 = viewModel.data.collectAsState()
    val counter2 = viewModel2.counter.collectAsState();
    Column {

        Text(text = counter1.value.toString())
        Text(text = counter2.value.toString())

        Button(modifier = Modifier,
            onClick = onClicked
            ) {
            Text(text = "更新")
        }
        Button(
            modifier=Modifier,
            onClick = onClicked2
        ) {
            Text(text="更新2")
        }

    }

}

5.Activity中调用代码

Kotlin 复制代码
var viewModel1=ViewModelProvider(this).get(TestViewModel1::class.java)
            var viewModel2 = ViewModelProvider(this).get(TestViewModel2::class.java)


            TestViewModelTheme {
                Surface(
                    modifier = Modifier.fillMaxSize(),
                )
                {
                    Row (
                        modifier = Modifier.fillMaxSize(),
                        verticalAlignment = Alignment.CenterVertically,
                        horizontalArrangement = Arrangement.Center
                    ){
                        TestViewModelScreen(
                            viewModel = viewModel1,
                            viewModel2=viewModel2,
                            onClicked = {
                                viewModel1.updateCounter1()
                            },
                            onClicked2 = {
                                viewModel2.updateCounter()
                            }
                        )
                    }

                }
            }

6.结果

通过两个不同的viewModel,可以对仓库类中的一个变量进行操作,并同步可显示双方操作结果。

相关推荐
Yang-Never5 分钟前
ADB -> pull指令推送电脑文件到手机上
android·adb·android studio
李新_7 分钟前
我们封装了哪些好用的Flutter Mixin
android·flutter
帅次21 分钟前
Flutter Expanded 与 Flexible 详解
android·flutter·ios·小程序·webview
流浪汉kylin24 分钟前
Android手机如何腾出存储空间
android
0wioiw01 小时前
Kotlin基础(①)
android·开发语言·kotlin
西瓜本瓜@1 小时前
在 Android 中实现通话录音
android·java·开发语言·学习·github·android-studio
浩浩测试一下2 小时前
信息收集之hack用的网络空间搜索引擎
android·网络·安全·web安全·搜索引擎·网络安全·安全架构
齐格Insight2 小时前
Capacitor 框架下解决One of RECEIVER_EXPORTED or RECEIVER_NOT_EXPORTED should be ...
android
芦半山2 小时前
后AOSP时代还能贡献代码吗?
android·源码
V少年3 小时前
深入浅出Java编译过程
android