如何在 Jetpack Compose 中获取上下文

Mr.*_*hal 46 android kotlin android-jetpack android-jetpack-compose

fun createListItem(itemIndex: Int) {
Padding(left = 8.dp, right = 8.dp, top = 8.dp, bottom = 8.dp) {
    FlexRow(crossAxisAlignment = CrossAxisAlignment.Center) {
        expanded(1.0f) {
            Text("Item $itemIndex")
        }
        inflexible {
            Button(
                "Button $itemIndex",
                style = ContainedButtonStyle(),
                onClick = {
                    Toast.makeText(
                        this@MainActivity,
                        "Item name $itemIndex",
                        Toast.LENGTH_SHORT
                    ).show()
                })

        }
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

我尝试以正常方式制作 Toast。但我得到了错误我尝试了很多倍数来源但失败了。

小智 85

2021 年 3 月更新:先前的答案已被弃用。你现在应该使用:

val context = LocalContext.current
Run Code Online (Sandbox Code Playgroud)

以前的答案供参考:

您可以使用 define 访问上下文ambientContext

例子:

val context = ContextAmbient.current
Run Code Online (Sandbox Code Playgroud)


Ana*_*har 31

ContextAmbientAmbientContext已弃用

更新

现在 Jetpack 执行此操作的方法已更新。下雪了:

val context = LocalContext.current
Run Code Online (Sandbox Code Playgroud)

  • @IgorGanapolsky 一旦有了本地上下文, context.getApplicationContext() (2认同)

Ran*_*mar 30

LocalContext.current - 是正确的方法。但问题是你不能在 @Composable 函数中使用 LocalContext.current

您需要创建单独的函数才能使用 Context

示例代码

@Composable
fun DoneButton() {
    val context = LocalContext.current
    Button(onClick = { showToast(context, "Button clicked")}) {
        Text(name = "Done")
    }
}

fun showToast(context: Context, msg: String) {
    Toast.makeText(context, msg, Toast.LENGTH_LONG).show()
}
Run Code Online (Sandbox Code Playgroud)


Ahm*_*lla 20

ContextAmbientAmbientContext已弃用

您可以将它们替换为

val context = LocalContext.current
Run Code Online (Sandbox Code Playgroud)


mit*_*tch 18

ContextAmbient.currentalpha-09.

AmbientContext.current已弃用。我认为alpha-11.

LocalContext.current 是您现在如何在可组合中获取上下文。


Rya*_*ley 14

执行此操作的方法已更新。下雪了:

val context = LocalContext.current
Run Code Online (Sandbox Code Playgroud)

本地上下文文档


Bri*_*iso 14

ContextAmbient.current已被弃用,请使用val context = LocalContext.current


bru*_*max 8

如果您需要从上一个 Android Studio 模板获取上下文作为 Activity,一些有用的:

val view = LocalView.current
(view.context as Activity).<activity method>
Run Code Online (Sandbox Code Playgroud)

更好的解决方案

fun Context.getActivity(): Activity? = when (this) {
    is Activity -> this
    is ContextWrapper -> baseContext.getActivity()
    else -> null
}

val activity = LocalContext.current.getActivity()
Run Code Online (Sandbox Code Playgroud)


Ali*_*lam 6

要获取 jetpack 中的上下文,请执行以下操作:

val context = ContextAmbient.current
Run Code Online (Sandbox Code Playgroud)

正在开发 0.1.0-dev14

如何在TOAST中使用它:

@Composable
fun cardViewImplementer(item: Int) {
   val context = ContextAmbient.current
   Card(
     shape = RoundedCornerShape(10.dp),
     modifier = Modifier.padding(10.dp)
   ) {
     Box(
        modifier = Modifier
            .fillMaxWidth()
            .drawShadow(5.dp)
            .clickable(onClick = {
                Toast.makeText(context, "Clicked $item", Toast.LENGTH_SHORT).show()
            }), children = {

        })
}
Run Code Online (Sandbox Code Playgroud)

用于访问资源

Text("Read this string: "+context.getString(R.string.name))
Run Code Online (Sandbox Code Playgroud)


Gia*_*chi 5

有问题compose_version = '1.0.0-alpha12'吗? AmbientContext就是现在LocalContext