jetpack Compose学习_键盘不可见时清除焦点,点击空白处隐藏键盘

由于 TextField被点击时会获取焦点,导致手机回退键需要点击两次才能退回到上个页面,所以在键盘隐藏的时候清除焦点

//键盘不可见时清除焦点
@Composable
fun KeyboardForClearFocus(window: Window){
    //键盘不可见时清除焦点
    val focusManager = LocalFocusManager.current
    val isKeyboardOpen by keyboardAsState()
    WindowCompat.setDecorFitsSystemWindows(window, false)
    if (!isKeyboardOpen) {
        DisposableEffect(Unit) {
            focusManager.clearFocus()
            onDispose {}
        }
    }
}

//键盘不可见时清除焦点
@Composable
fun keyboardAsState(): State<Boolean> {
    val isImeVisible =
        WindowInsets.ime.getBottom(LocalDensity.current) > 0
    return rememberUpdatedState(isImeVisible)
}

点击空白处隐藏键盘,参考文档:compose 点击空白区域取消软键盘_compose 点击空白处 输入法消失-CSDN博客

@Composable
fun Modifier.autoCloseKeyboard(): Modifier = composed {
    //LocalSoftwareKeyboardController 这个是compose 组件,必须在compose 函数内才能使用
    val keyboardController = LocalSoftwareKeyboardController.current
    pointerInput(this) {
        detectTapGestures(
            onPress = {
                keyboardController?.hide()
            }
        )
    }
}

//使用的时候设置在外层
 Column (verticalArrangement= Arrangement.Center , modifier = Modifier.autoCloseKeyboard()){
    //UI
}

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值