作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要在 jetpack compose 中使用这样的掩码的文本字段:NNNNN-NNN
其中 N 是从 0 到 9 的整数。我需要我的可组合函数在 OutlinedTextField
中有这个掩码:
@Composable
private fun EditTextField(
labelText: String,
value: String,
keyboardType: KeyboardType = KeyboardType.Text,
onValueChanged: (String) -> Unit
) {
OutlinedTextField(
modifier = Modifier.padding(top = 8.dp),
label = { Text(text = labelText) },
keyboardOptions = KeyboardOptions(keyboardType = keyboardType),
value = value,
onValueChange = onValueChanged
)
}
最佳答案
您可以使用 visualTransformation
属性(property):
OutlinedTextField(
value = text,
onValueChange = { it ->
text = it.filter { it.isDigit() }
},
keyboardOptions = KeyboardOptions(keyboardType = KeyboardType.Number),
visualTransformation = MaskTransformation()
)
和:
class MaskTransformation() : VisualTransformation {
override fun filter(text: AnnotatedString): TransformedText {
return maskFilter(text)
}
}
fun maskFilter(text: AnnotatedString): TransformedText {
// NNNNN-NNN
val trimmed = if (text.text.length >= 8) text.text.substring(0..7) else text.text
var out = ""
for (i in trimmed.indices) {
out += trimmed[i]
if (i==4) out += "-"
}
val numberOffsetTranslator = object : OffsetMapping {
override fun originalToTransformed(offset: Int): Int {
if (offset <= 4) return offset
if (offset <= 8) return offset +1
return 9
}
override fun transformedToOriginal(offset: Int): Int {
if (offset <=5) return offset
if (offset <=9) return offset -1
return 8
}
}
return TransformedText(AnnotatedString(out), numberOffsetTranslator)
}
关于android - 如何在jetpack compose中创建带有掩码的文本字段输入?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69064137/
我是一名优秀的程序员,十分优秀!