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>
相关推荐
_李小白15 小时前
【android opencv学习笔记】Day 2: Mat类(图片数据结构体)
android·opencv·学习
harder32116 小时前
RMP模式的创新突破
开发语言·学习·ios·swift·策略模式
jinanwuhuaguo16 小时前
OpenClaw工程解剖——RAG、向量织构与“记忆宫殿”的索引拓扑学(第十三篇)
android·开发语言·人工智能·kotlin·拓扑学·openclaw
Rust研习社16 小时前
使用 Axum 构建高性能异步 Web 服务
开发语言·前端·网络·后端·http·rust
淘矿人18 小时前
从0到1:用Claude启动你的第一个项目
开发语言·人工智能·git·python·github·php·pygame
cany100018 小时前
C++ -- 模板的声明和定义
开发语言·c++
澈20718 小时前
深耕进阶 Day1:C 与 C++ 核心差异 + C++ 入门基石
c语言·开发语言·c++
小怪吴吴18 小时前
idea 开发Android
android·java·intellij-idea
Felven18 小时前
C. Need More Arrays
c语言·开发语言
love530love18 小时前
Podman Machine 虚拟硬盘迁移实战二:用 Junction 把 vhdx 从 C 盘搬到其他盘
c语言·开发语言·人工智能·windows·wsl·podman·podman machine