在Jetpack Compose中设置对焦顺序最简单的方法是什么?

What is the simplest way to set the focus order in Jetpack Compose?(在Jetpack Compose中设置对焦顺序最简单的方法是什么?)
本文介绍了在Jetpack Compose中设置对焦顺序最简单的方法是什么?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一列文本字段,类似于:

Column {
    TextField(
        value = ...,
        onValueChange = { ... },
        keyboardOptions = KeyboardOptions(imeAction = ImeAction.next),
    )
    TextField(
        value = ...,
        onValueChange = { ... },
        keyboardOptions = KeyboardOptions(imeAction = ImeAction.next),
    )
    .
    .
    .
}
当用户按下Tab或键盘上的Next按钮时,我希望将焦点移到每个Textfield上的下一个。当前按Tab可在文本字段中插入一个制表符。按Next(下一步)按钮不起任何作用。我可以为每个文本字段创建一个FocusRequester,并将keyboardActions onNext设置为请求每个文本字段的下一个字段上的焦点。这有点单调乏味,而且没有解决Tab行为。

推荐答案

我最近找到了这篇文章:https://medium.com/google-developer-experts/focus-in-jetpack-compose-6584252257fe

它解释了另一种处理焦点的方法,这种方法要简单得多。

val focusManager = LocalFocusManager.current
TextField(
    modifier = Modifier
        .onPreviewKeyEvent {
            if (it.key == Key.Tab){
                focusManager.moveFocus(FocusDirection.Down)
                true
            } else {
                false
            }
        },
    value = text,
    onValueChange = { it -> text = it },
    keyboardOptions = KeyboardOptions(imeAction = ImeAction.Next),
    keyboardActions = KeyboardActions(
        onNext = { focusManager.moveFocus(FocusDirection.Down) }
    )
)

这篇关于在Jetpack Compose中设置对焦顺序最简单的方法是什么?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

How to target newer versions in .gitlab-ci.yml using auto devops (java 11 instead of 8 and Android 31 instead of 29)(如何在.gitlab-ci.yml中使用自动开发工具(Java 11而不是8,Android 31而不是29)瞄准较新的版本)
Android + coreLibraryDesugaring: which Java 11 APIs can I expect to work?(Android+core LibraryDesugering:我可以期待哪些Java 11API能够工作?)
How to render something in an if statement React Native(如何在If语句中呈现某些内容Reaction Native)
How can I sync two flatList scroll position in react native(如何在本机Reaction中同步两个平面列表滚动位置)
Using Firebase Firestore in offline only mode(在仅脱机模式下使用Firebase FiRestore)
Crash on Google Play Pre-Launch Report: java.lang.NoSuchMethodError(Google Play发布前崩溃报告:java.lang.NoSuchMethodError)