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,可以对仓库类中的一个变量进行操作,并同步可显示双方操作结果。

相关推荐
2501_915918411 小时前
uni-app 项目 iOS 上架踩坑经验总结 从证书到审核的避坑指南
android·ios·小程序·https·uni-app·iphone·webview
游戏开发爱好者81 小时前
iOS 上架 uni-app 流程全解析,从打包到发布的完整实践
android·ios·小程序·https·uni-app·iphone·webview
雨白6 小时前
实现双向滑动的 ScalableImageView(上)
android
Y4090016 小时前
数据库基础知识——聚合函数、分组查询
android·数据库
没有了遇见11 小时前
Android 原生定位(替代高德 / 百度等三方定位)<终极版本>
android
2501_9160088912 小时前
iOS 抓包工具有哪些?全面盘点主流工具与功能对比分析
android·ios·小程序·https·uni-app·iphone·webview
2501_9159214312 小时前
iOS混淆工具实战 视频流媒体类 App 的版权与播放安全保护
android·ios·小程序·https·uni-app·iphone·webview
CYRUS_STUDIO13 小时前
LLVM 全面解析:NDK 为什么离不开它?如何亲手编译调试 clang
android·编译器·llvm
CYRUS_STUDIO13 小时前
静态分析神器 + 动态调试利器:IDA Pro × Frida 混合调试实战
android·逆向
g_i_a_o_giao15 小时前
Android8 binder源码学习分析笔记(一)
android·java·笔记·学习·binder·安卓源码分析