18

我通过尝试一些像 Image 和 EditText 这样的小部件来探索 Jetpack compose。

对于文本输入,它具有EditableText. 我试过下面的代码,但它没有在 UI 中显示任何内容

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContent {
            loadUi()
        }
    }

    @Composable
    fun loadUi() {
        CraneWrapper {
            MaterialTheme {
                val state = +state { EditorState("") }
                EditableText(
                    value = state.value,
                    onValueChange = { state.value = it },
                    editorStyle = EditorStyle(
                        textStyle = TextStyle(
                            fontSize = (50f)
                        )
                    )
                )
            }
        }
    }
}

我在这里想念什么?任何帮助,将不胜感激!

4

5 回答 5

16

正如Gabriele Mariotti的回答所述,这是正确的做法:

var text by rememberSaveable { mutableStateOf("Text") }

TextField(
    value = text,
    onValueChange = {
        text = it
    },
    label = { Text("Label") }
)

但是,如果您遇到以下错误:

类型“TypeVariable(T)”没有方法“getValue(MainActivity, KProperty<*>)”,因此它不能用作委托

只需将这两个导入添加到您的文件中,您就可以了:

import androidx.compose.runtime.getValue
import androidx.compose.runtime.setValue
于 2021-06-02T15:52:36.063 回答
11

有了1.0.x你就可以了TextField

就像是:

var text by rememberSaveable { mutableStateOf("Text") }

TextField(
    value = text,
    onValueChange = {
        text = it
    },
    label = { Text("Label") }
)

在此处输入图像描述

额外细节:

https://developer.android.com/jetpack/compose/text#enter-modify-text

于 2020-08-30T10:24:30.207 回答
3

对不起,迟到的答案。API 进行了一些更改,因此您的代码现在应该如下所示:

@Composable
fun loadUi() {
    val state = +state { EditorModel("smth") }
    TextField(
        value = state.value,
        onValueChange = { state.value = it },
        editorStyle = EditorStyle(
            textStyle = TextStyle(
                fontSize = (50.sp)
            )
        )
    )
}

您也可能会错过小部件,因为它没有默认背景,并且如果您有空字符串,默认情况下几乎不可见

于 2019-08-31T09:39:27.917 回答
2
TextField(
    value = state.value,
    onValueChange = { new ->
        state.value = if (new.text.any { it == '\n' }) {
            state.value
        } else {
            new
        }
    },
    keyboardType = KeyboardType.Text,
    imeAction = ImeAction.Search,
    textStyle = TextStyle(color = Color.DarkGray),
    onImeActionPerformed = onImeActionPerformed
)
于 2019-12-23T14:09:41.307 回答
-1
 val state = +state {
                    EditorModel("Edit Text")
                }
                TextField(
                    value = state.value,
                    onValueChange = {
                        state.value = it
                    },
                    textStyle = TextStyle(
                        fontSize = (30.sp),
                        color = Color.DarkGray
                    ),
                    keyboardType = KeyboardType.Text
                )

试试这个。

于 2020-04-24T10:23:57.647 回答