Android Compose 中获取和使用 Context 的完整指南

在 Android Jetpack Compose 中,虽然大多数 UI 组件不再需要直接使用 Context,但有时你仍然需要访问它来执行一些 Android 平台特定的操作。以下是几种在 Compose 中获取和使用 Context 的方法:

1. 使用 LocalContext

这是 Compose 中最常用的获取 Context 的方式:

复制代码
@Composable
fun MyComposable() {
    val context = LocalContext.current
    
    Button(onClick = {
        Toast.makeText(context, "Hello from Compose!", Toast.LENGTH_SHORT).show()
    }) {
        Text("Show Toast")
    }
}

2. 通过参数传递 Context

对于可测试性和明确性,你可以选择将 Context 作为参数传递:

复制代码
@Composable
fun MyComposable(context: Context) {
    // 使用 context
}

3. 在非 @Composable 函数中获取 Context

如果你需要在非 Composable 函数中访问 Context,可以通过参数传递:

复制代码
fun nonComposableFunction(context: Context) {
    // 使用 context
}

@Composable
fun WrapperComposable() {
    val context = LocalContext.current
    nonComposableFunction(context)
}

常见使用场景
显示 Toast:

复制代码
Toast.makeText(context, "Message", Toast.LENGTH_SHORT).show()

启动 Activity:

复制代码
context.startActivity(Intent(context, MyActivity::class.java))

访问资源:

复制代码
val string = context.getString(R.string.app_name)

系统服务:

复制代码
val vibrator = context.getSystemService(Context.VIBRATOR_SERVICE) as Vibrator

注意事项

避免在 Composable 函数中长时间持有 Context 引用,这可能导致内存泄漏

对于资源访问,Compose 提供了更直接的替代方案,如 stringResource(R.string.app_name)

在主题和样式方面,Compose 有自己的系统,通常不需要直接使用 Context

其他相关的 Local 对象

除了 Context,Compose 还提供了其他有用的 Local 对象:

复制代码
val activity = LocalActivity.current
val configuration = LocalConfiguration.current
val resources = LocalResources.current

这些都可以在需要时通过类似的模式获取。

相关推荐
雨白2 小时前
指针与数组的核心机制
android
黄林晴7 小时前
Room 3.0 正式发布!包名彻底重构,KMP 成为核心主线
android·android jetpack
三少爷的鞋8 小时前
Kotlin 协程环境下的 DCL 懒加载:别把线程时代的经验直接搬过来
android
plainGeekDev8 小时前
Gson → kotlinx.serialization
android·java·kotlin
CYY951 天前
Compose 入门篇
android·kotlin
杉氧1 天前
Compose 时代的 MVI 架构:如何用单向数据流驱动复杂 UI?
android·架构·android jetpack
杉氧1 天前
Modifier 的艺术:为什么链式调用的顺序决定了UI 的生命周期?
android·架构·android jetpack
李斯维1 天前
腾讯 XLog 日志框架 Android 端接入
android·android studio·android jetpack
黄林晴1 天前
Kotlin Toolchain 0.11 发布:Amper 正式更名,统一 kotlin 命令
android·kotlin