Android-Kotlin基础(Jetpack③-LiveData)

和传统方式的核心区别:

传统方式需要手动调用 textView.setText() 更新 UI

传统方式需要自己处理屏幕旋转的数据保存

传统方式可能在 Activity 销毁后更新 UI 导致崩溃

CounterViewModel.kt

Kotlin 复制代码
import androidx.lifecycle.LiveData
import androidx.lifecycle.MutableLiveData
import androidx.lifecycle.ViewModel

// ViewModel 负责管理数据和业务逻辑
class CounterViewModel : ViewModel() {
    // 私有可变的 LiveData(内部修改)
    private val _count = MutableLiveData(0)
    
    // 公开不可变的 LiveData(供 UI 观察)
    val count: LiveData<Int> = _count

    // 增加计数的方法
    fun increment() {
        // 获取当前值,加1后更新(主线程用setValue)
        _count.value = _count.value?.plus(1)
    }

    // 重置计数的方法
    fun reset() {
        _count.value = 0
    }
}

MainActivity.kt

Kotlin 复制代码
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import androidx.lifecycle.ViewModelProvider
import com.example.livedatademo.databinding.ActivityMainBinding

class MainActivity : AppCompatActivity() {
    private lateinit var binding: ActivityMainBinding
    private lateinit var viewModel: CounterViewModel

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        // 初始化 DataBinding
        binding = ActivityMainBinding.inflate(layoutInflater)
        setContentView(binding.root)

        // 获取 ViewModel 实例
        viewModel = ViewModelProvider(this)[CounterViewModel::class.java]

        // 观察 LiveData 变化,自动更新 UI
        viewModel.count.observe(this) { newCount ->
            // 数据变化时自动执行,已在主线程
            binding.tvCount.text = "当前计数: $newCount"
        }

        // 绑定按钮点击事件
        binding.btnIncrement.setOnClickListener {
            viewModel.increment() // 只修改数据,UI 自动更新
        }

        binding.btnReset.setOnClickListener {
            viewModel.reset() // 只修改数据,UI 自动更新
        }
    }
}

activity_main.xml

XML 复制代码
<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        android:gravity="center"
        android:padding="16dp">

        <TextView
            android:id="@+id/tvCount"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="24sp"
            android:marginBottom="32dp"/>

        <Button
            android:id="@+id/btnIncrement"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="加1"
            android:layout_marginBottom="16dp"/>

        <Button
            android:id="@+id/btnReset"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="重置"/>

    </LinearLayout>
</layout>
相关推荐
3GPP仿真实验室15 分钟前
【Matlab源码】6G候选波形:OFDM-IM 增强仿真平台 DM、CI
开发语言·matlab·ci/cd
devmoon19 分钟前
在 Polkadot 上部署独立区块链Paseo 测试网实战部署指南
开发语言·安全·区块链·polkadot·erc-20·测试网·独立链
lili-felicity19 分钟前
CANN流水线并行推理与资源调度优化
开发语言·人工智能
沐知全栈开发20 分钟前
CSS3 边框:全面解析与实战技巧
开发语言
island131430 分钟前
CANN GE(图引擎)深度解析:计算图优化管线、内存静态规划与异构 Stream 调度机制
c语言·开发语言·神经网络
曹牧34 分钟前
Spring Boot:如何在Java Controller中处理POST请求?
java·开发语言
浅念-37 分钟前
C++入门(2)
开发语言·c++·经验分享·笔记·学习
WeiXiao_Hyy38 分钟前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
User_芊芊君子44 分钟前
CANN010:PyASC Python编程接口—简化AI算子开发的Python框架
开发语言·人工智能·python
Max_uuc1 小时前
【C++ 硬核】打破嵌入式 STL 禁忌:利用 std::pmr 在“栈”上运行 std::vector
开发语言·jvm·c++