【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
            }
        )
    }
}
相关推荐
2501_916008892 分钟前
iOS 26 软件性能测试全流程,启动渲染资源压力对比与优化策略
android·macos·ios·小程序·uni-app·cocoa·iphone
zh_xuan21 分钟前
Android Handler源码阅读
android
雪饼android之路37 分钟前
【Android】 android suspend/resume总结(3)
android·linux
00后程序员张37 分钟前
iOS 26 兼容测试实战,机型兼容、SwiftUI 兼容性改动
android·ios·小程序·uni-app·swiftui·cocoa·iphone
molong9311 小时前
Android 应用配置跳转微信小程序
android·微信小程序·小程序
2501_915106322 小时前
iOS 可分发是已经上架了吗?深入解析应用分发状态、ipa 文件上传、TestFlight 测试与 App Store 审核流程
android·ios·小程序·https·uni-app·iphone·webview
安东尼肉店10 小时前
Android compose屏幕适配终极解决方案
android
2501_9160074710 小时前
HTTPS 抓包乱码怎么办?原因剖析、排查步骤与实战工具对策(HTTPS 抓包乱码、gzipbrotli、TLS 解密、iOS 抓包)
android·ios·小程序·https·uni-app·iphone·webview
feiyangqingyun11 小时前
基于Qt和FFmpeg的安卓监控模拟器/手机摄像头模拟成onvif和28181设备
android·qt·ffmpeg
用户20187928316715 小时前
ANR之RenderThread不可中断睡眠state=D
android