在 Kotlin Multiplatform 上复制到剪贴板
Copying to clipboard on Kotlin Multiplatform
到目前为止我找不到任何人这样做,所以我会尝试并正确说明我面临的问题。
我的 KMP 应用程序 shared module
中有一个 compose-ui
模块。 compose-ui
有一个 commonMain
目录,所有撰写 UI 所在的目录(在桌面和 android 应用程序之间共享的屏幕)。现在的问题是,要将文本复制到剪贴板(在 Android 上),您需要上下文,在 commonMain 中无法访问它,好的,没问题,我将不得不期待/实际功能 @Composable copyToClipboard(text: string)
,但使用 IconButton
及其 OnClick : () -> Unit
会导致错误 @Composable can only be called from composable context
。我不知道该怎么做,我不知何故需要上下文来访问剪贴板管理器,但我无法访问它也无法传递它。
像这样的东西应该可以工作,它是你的 androidMain:
@Composable
fun copyClipboardLambda(): () -> Unit {
val context = LocalContext.current
return {
context.yourCopyFunc()
}
}
在您看来:
@Composable
fun View() {
val copyClipboard = copyClipboardLambda()
Box(
modifier = Modifier.clickable {
copyClipboard()
}
)
}
到目前为止我找不到任何人这样做,所以我会尝试并正确说明我面临的问题。
我的 KMP 应用程序 shared module
中有一个 compose-ui
模块。 compose-ui
有一个 commonMain
目录,所有撰写 UI 所在的目录(在桌面和 android 应用程序之间共享的屏幕)。现在的问题是,要将文本复制到剪贴板(在 Android 上),您需要上下文,在 commonMain 中无法访问它,好的,没问题,我将不得不期待/实际功能 @Composable copyToClipboard(text: string)
,但使用 IconButton
及其 OnClick : () -> Unit
会导致错误 @Composable can only be called from composable context
。我不知道该怎么做,我不知何故需要上下文来访问剪贴板管理器,但我无法访问它也无法传递它。
像这样的东西应该可以工作,它是你的 androidMain:
@Composable
fun copyClipboardLambda(): () -> Unit {
val context = LocalContext.current
return {
context.yourCopyFunc()
}
}
在您看来:
@Composable
fun View() {
val copyClipboard = copyClipboardLambda()
Box(
modifier = Modifier.clickable {
copyClipboard()
}
)
}