大佬教程收集整理的这篇文章主要介绍了在 Jetpack Compose 中关闭键盘时如何清除 TextField 焦点?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用 OutlinedTextFIEld。
当我开始编辑时,后退按钮变成隐藏键盘按钮(向下箭头)。
第一次按下后退按钮会隐藏键盘,但焦点仍在文本字段上。未调用 onFocusChanged
和 BACkPressHandler
处理程序。
第二次按下后退按钮清除焦点:onFocusChanged
被调用,而 BACkPressHandler
不是。
BACkPressHandler {
println("BACkPressHandler")
}
val valueState = remember { mutableStateOf(TextFIEldValue(text = "")) }
OutlinedTextFIEld(
value = valueState.value,onValueChange = {
valueState.value = it
},modifIEr = ModifIEr
.fillMaxWIDth()
.onFocusChanged {
println("isFocused ${it.isFocuseD}")
}
)
第三次 BACkHandler 工作正常,我从 compose-samples 获取 if。只是用于测试,我不应该在这里需要它,它预计在第一次点击后退按钮后焦点会丢失
带有焦点文本字段的 compose issue 可防止后退按钮在键盘隐藏时关闭应用程序。它被标记为已修复,但将包含在未来的某个版本中,而不是包含在 1.0
但是,据我了解,在键盘被解除后文本字段没有失去焦点的事实是 Android 上的预期行为(因为可能连接了键盘?我没有得到原因)。这也是它在旧的 android 布局中的工作方式
这对我来说似乎很奇怪,所以我提供了以下修饰符,它在键盘消失时退出焦点:
fun Modifier.fixKeyboardFocusIssue(): Modifier = composed {
var isFocused by remember { mutableStateOf(false) }
val scope = rememberCoroutInescope()
if (isFocused) {
// TODO: replace with single if when https://issuetracker.google.com/issues/193907134 fixed
if (!LocalWindowInsets.current.ime.isVisiblE) {
LocalFocusmanager.current.clearFocus()
}
}
onFocusChanged {
if (it.isFocused && !isFocused) {
scope.launch {
// wait until keyboard presented on start ediTing
delay(300)
isFocused = it.isFocused
}
} else {
isFocused = it.isFocused
}
}
}
用法:
BasicTextField(
value = valueState.value,onValueChange = {
valueState.value = it
},modifier = Modifier
.fixKeyboardFocusIssue()
)
以上是大佬教程为你收集整理的在 Jetpack Compose 中关闭键盘时如何清除 TextField 焦点?全部内容,希望文章能够帮你解决在 Jetpack Compose 中关闭键盘时如何清除 TextField 焦点?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。