kotlin,jetpack compose,使用DataStore保存数据,让程序下次启动时自动获取

复制代码
implementation ("androidx.datastore:datastore-preferences:1.0.0")
复制代码
package com.example.mydatastore

import android.content.Context
import android.os.Bundle
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.activity.enableEdgeToEdge
import androidx.compose.foundation.text.KeyboardOptions
import androidx.compose.material3.TextField
import androidx.compose.runtime.*
import androidx.compose.ui.platform.LocalContext
import androidx.compose.ui.text.input.KeyboardType
import androidx.datastore.core.DataStore
import androidx.datastore.preferences.core.Preferences
import androidx.datastore.preferences.core.edit
import androidx.datastore.preferences.core.intPreferencesKey
import androidx.datastore.preferences.preferencesDataStore
import com.example.mydatastore.ui.theme.MyDataStoreTheme
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.launch

// MainActivity 是应用的入口 Activity,继承自 ComponentActivity
class MainActivity : ComponentActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        // 启用边缘到边缘的显示模式
        enableEdgeToEdge()
        // 设置 Compose 内容
        setContent {
            MyDataStoreTheme {
                // 显示 NumberInputScreen 组件
                NumberInputScreen()
            }
        }
    }
}

// 定义 DataStore 的扩展属性,用于访问应用的设置数据存储
val Context.settingsDataStore: DataStore<Preferences> by preferencesDataStore(name = "my_settings")

// NumberInputScreen 是一个可组合函数,用于显示数字输入界面
@Composable
fun NumberInputScreen() {
    // 获取当前上下文
    val context = LocalContext.current
    // 使用 remember 和 mutableStateOf 来保存输入的数字
    var number by remember { mutableStateOf(0) }

    // 使用 LaunchedEffect 在组合时执行一次,从 DataStore 读取初始值
    LaunchedEffect(Unit) {
        context.settingsDataStore.data.collect { preferences ->
            number = preferences[PreferencesKeys.NUMBER] ?: 0
        }
    }

    // 显示一个 TextField,用于输入数字
    TextField(
        value = number.toString(),
        onValueChange = { newValue ->
            // 将输入的值转换为整数,如果转换成功则更新状态并保存到 DataStore
            newValue.toIntOrNull()?.let { num ->
                number = num
                // 在 IO 线程中异步保存到 DataStore
                CoroutineScope(Dispatchers.IO).launch {
                    context.settingsDataStore.edit { settings ->
                        settings[PreferencesKeys.NUMBER] = num
                    }
                }
            }
        },
        // 设置键盘类型为数字键盘
        keyboardOptions = KeyboardOptions(keyboardType = KeyboardType.Number)
    )
}

// PreferencesKeys 是一个单例对象,用于定义 DataStore 的键
private object PreferencesKeys {
    val NUMBER = intPreferencesKey("saved_number")
}
相关推荐
石山岭28 分钟前
自己动手写了一个 Android 虚拟定位 App:GPSSimulate 技术实
android·前端
杉氧3 小时前
副作用 (Side Effects) 全攻略:如何像大师一样掌控 Composable 的生命周期?
android·架构·android jetpack
唐青枫6 小时前
别再把 inline 当性能开关:Kotlin 内联、noinline、crossinline 与 reified 实战详解
kotlin
Kapaseker7 小时前
Kotlin Toolchain 0.11 发布:主要是把 Amper 干没了
android·kotlin
黄林晴7 小时前
AndroidX 官宣信号:Compose版WebView要来了!
kotlin
三少爷的鞋8 小时前
Android 现代架构不需要事件总线进阶篇
android
杉氧1 天前
深入理解 Compose 重组机制:快照系统如何驱动 UI 精准刷新?
android·架构·android jetpack
召钱熏1 天前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
杉氧1 天前
深度解析:Jetpack Compose 核心架构与底层原理 —— 十年安卓老兵的“破茧重生”
android·架构·android jetpack
通玄1 天前
Jetpack Compose 入门系列(七):ViewModel 与界面状态管理
android