【Compose】Android Compose 监听TextField粘贴事件

背景

项目中需要监听输入框(也就是TextField组件)的粘贴事件,Compose的TextField不像android.view的EditText中一样,重写onTextContextMenuItem方法就可以做到监听,Compose中而是使用改变provider来实现。

实现

1. 获取本地TextToolbar

kotlin 复制代码
val defaultTextToolbar = LocalTextToolbar.current

2. 重写TextToolbar

kotlin 复制代码
val pasteListeningTextToolbar = remember{
    object : TextToolbar {
        override fun hide() {
            defaultTextToolbar.hide()
        }

        override val status: TextToolbarStatus
            get() = defaultTextToolbar.status

        override fun showMenu(
            rect: Rect,
            onCopyRequested: (() -> Unit)?,
            onPasteRequested: (() -> Unit)?,
            onCutRequested: (() -> Unit)?,
            onSelectAllRequested: (() -> Unit)?
        ) {
            val wrappedPasteCallback = {
                onPasteRequested?.invoke()
                println("paste event happen")
            }

            defaultTextToolbar.showMenu(
                rect,
                onCopyRequested,
                wrappedPasteCallback,
                onCutRequested,
                onSelectAllRequested,
            )
        }
    }
}

关键点

只拦截粘贴事件,其他保持不变

kotlin 复制代码
val wrappedPasteCallback = {
    onPasteRequested?.invoke() // 保持原始粘帖功能
    // 添加自定义逻辑,也可以加自定义的callback,我这里直接输入
    println("paste event happen")
}

其后,再把其他功能回调原封不动的传递给默认TextToolbar

kotlin 复制代码
defaultTextToolbar.showMenu(
    rect,
    onCopyRequested,         // 原始复制功能
    wrappedPasteCallback,    // 包装后的粘贴
    onCutRequested,          // 原始剪切功能
    onSelectAllRequested      // 原始全选功能
)

3. 替换默认的TextToolbar

替换原有的TextToolbar,为自定义的TextToolbar

kotlin 复制代码
CompositionLocalProvider(LocalTextToolbar providers pasteListeningTextToolbar){
    TextField(
        value = text,
        onValueChange = { text = id },
    )
}

完整Composeable代码

kotlin 复制代码
@Composable
fun TextFieldWithPasteCallback(
) {
    var text by remember { mutableStateOf("") }
    var state = rememberTextFieldState()
    var defaultTextToolbar = LocalTextToolbar.current

    var pasteListeningToolbar = remember {
        object : TextToolbar {
            override fun hide() {
                defaultTextToolbar.hide()
            }

            override val status: TextToolbarStatus
                get() = defaultTextToolbar.status

            override fun showMenu(
                rect: Rect,
                onCopyRequested: (() -> Unit)?,
                onPasteRequested: (() -> Unit)?,
                onCutRequested: (() -> Unit)?,
                onSelectAllRequested: (() -> Unit)?
            ) {
                val wrappedPasteCallback = {
                    onPasteRequested?.invoke()
                    println("paste event happen")
                }

                defaultTextToolbar.showMenu(
                    rect,
                    onCopyRequested,
                    wrappedPasteCallback,
                    onCutRequested,
                    onSelectAllRequested,
                )
            }
        }
    }

    CompositionLocalProvider(LocalTextToolbar provides pasteListeningToolbar) {
        TextField(
            placeholder = {
                Text("input placeholder")
            },
            value = text,
            onValueChange = {
                println("text:$it")
                text = it
            }
        )
    }
}
相关推荐
tangweiguo0305198725 分钟前
Kotlin 实现 Android 网络状态检测工具类
android·网络·kotlin
nvvas2 小时前
Android Studio JAVA开发按钮跳转功能
android·java·android studio
怪兽20142 小时前
Android多进程通信机制
android·面试
叶羽西2 小时前
Android CarService调试操作
android
千里马-horse2 小时前
在android中 spdlog库的log如何在控制台上输出
android·c++·spdlog
Zender Han3 小时前
《从零搭建现代 Android 模块化架构项目(2025 最新实践)》
android·架构
Digitally3 小时前
如何从电脑上卸载安卓应用程序
android·电脑
Mr YiRan3 小时前
多线程性能优化基础
android·java·开发语言·性能优化
liyi_hz20084 小时前
O2OA (翱途)开发平台新版本发布预告:架构升级、性能跃迁、功能全面进化
android·java·javascript·开源软件
Huangyi4 小时前
第一节:Flow的基础知识
android·前端·kotlin