Compose中快捷监听软键盘收起弹出状态方法(兼容Android各个版本)

文章介绍了如何在JetpackCompose中监听软键盘的收起和弹出状态,提供了非Compose方法以及适用于Compose的解决方案,包括针对Android10及更高版本的适配代码。同时强调了在多页面路由中监听软键盘状态需要注意的问题和解决办法。

Compose中快捷监听软键盘收起弹出状态方法

非compose方法监听软键盘收起

在我们开发compose项目之前就有很多获取软键盘状态的方法,比如如下法1:

 fun getImeVisible(activity: Activity, callback: WindowsKeyboardCallback? = null) {
   
    //判断软键盘是否收起
        ViewCompat.setOnApplyWindowInsetsListener(activity.window.decorView) {
   
    _, insets ->
            val imeVisible = insets.isVisible(WindowInsetsCompat.Type.ime())
            val imeHeight = insets.getInsets(WindowInsetsCompat.Type.ime()).bottom
            callback?.onKeyboardChanged(imeVisible, imeHeight)
            WindowInsetsCompat.CONSUMED
        }
    }

但是这种不适合navigation的多页面路由中使用判断,会导致状态栏显示异常。
方法二:

fun Activity.listenForKeyboardVisibilityChange(callback: (Boolean) -> Unit)<
Android Compose 里,要保证底部输入和弹出软键盘距离为 20dp,可以借助 `Modifier` 里的 `imePadding()` 修饰符来处理。不过,`imePadding()` 仅提供与软键盘的内边距,不能直接设定为 20dp。可结合 `WindowInsets` 与 `Modifier.padding` 达成该效果。 以下是示例代码: ```kotlin import androidx.compose.foundation.layout.Box import androidx.compose.foundation.layout.fillMaxSize import androidx.compose.foundation.layout.padding import androidx.compose.material.TextField import androidx.compose.runtime.Composable import androidx.compose.ui.Modifier import androidx.compose.ui.platform.LocalSoftwareKeyboardController import androidx.compose.ui.unit.dp import androidx.core.view.WindowInsetsCompat @Composable fun InputWithKeyboardPadding() { val keyboardController = LocalSoftwareKeyboardController.current Box( modifier = Modifier .fillMaxSize() ) { // 底部输入框 TextField( value = "", onValueChange = { }, modifier = Modifier .padding(bottom = 20.dp) // 设置底部输入框与键盘的距离 .imePadding() // 处理软键盘内边距 ) } } ``` 在上述代码中,`TextField` 是底部输入框,借助 `Modifier.padding(bottom = 20.dp)` 设定底部输入框和键盘的距离为 20dp,同时使用 `imePadding()` 来处理软键盘的内边距。 如果要更精准地控制软键盘的显示和隐藏,可使用 `LocalSoftwareKeyboardController`。 ### 注意事项 - 要确保在 `AndroidManifest.xml` 里为对应的 Activity 设置合适的 `android:windowSoftInputMode` 属性,像 `adjustResize`,从而让窗口能正确地响应软键盘的显示和隐藏。 - 不同设备和 Android 版本或许存在兼容性问题,需要进行充分的测试。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雪の星空朝酱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值