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

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

相关推荐
liang_jy2 小时前
Android SparseArray
android·源码
liang_jy2 小时前
Activity 启动流程扩展篇(一)—— startActivityInner 任务决策全解析
android·源码
NPE~3 小时前
[App逆向]脱壳实战
android·教程·逆向·android逆向·逆向分析
木易 士心4 小时前
别再只会用 drawCircle 了!一文搞懂 Android Canvas 底层机制
android
AtOR CUES5 小时前
MySQL——表操作及查询
android·mysql·adb
怣疯knight6 小时前
安卓App无法增加自定义图片作为图标功能
android
jinanwuhuaguo8 小时前
OpenClaw联邦之心——从孤岛记忆到硅基集体潜意识的拓扑学革命(第二十三篇)
android·人工智能·kotlin·拓扑学·openclaw
Gary Studio9 小时前
安卓HAL C++基础-命名域
android
诸神黄昏EX10 小时前
Android Google XTS
android
eSsO KERF10 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql