Что это должно делать:
При нажатии кнопки , откройте наложение двух TextFields, чтобы редактировать информацию из mutablestatelistof.
По завершении закройте наложение и обновите пользовательский интерфейс на основе информации, введенной в наложение.
Довольно просто концепция, но проблема заключается в рекомпозиции.
Код: Выделить всё
val groupComponents = remember {
mutableStateListOf()
}
val boxVisible = remember {
mutableStateOf(false)
}
val boxElementIndex = remember {
mutableIntStateOf(0)
}
val boxGroupIndex = remember {
mutableIntStateOf(0)
}
val boxName = remember {
mutableStateOf("")
}
val boxCommand = remember {
mutableStateOf("")
}
EditCustomUIBoxOverlay(
boxVisible,
boxName,
boxCommand,
close = {
boxVisible.value = !boxVisible.value
},
processBoxData = { name, command ->
val list = groupComponents[boxGroupIndex.value].elements
list[boxElementIndex.value].name = name.value
list[boxElementIndex.value].data = command.value
groupComponents[boxGroupIndex.value].copy(
elements = list
)
})
@Composable
fun EditCustomUIBoxOverlay(
boxVisible: MutableState,
boxName: MutableState,
boxCommand: MutableState,
processBoxData: (MutableState, MutableState) -> Unit,
close: () -> Unit
) {
AnimatedVisibility(
visible = boxVisible.value,
enter = fadeIn(),
exit = fadeOut()
) {
Box(
modifier = Modifier
.fillMaxSize()
.background(color = Color(0.0f, 0f, 0f, 0.5f)),
contentAlignment = Alignment.Center
) {
ElevatedCard(
modifier = Modifier
.padding(15.dp)
.defaultMinSize()) {
Row(
modifier = Modifier.defaultMinSize(),
horizontalArrangement = Arrangement.Center
) {
TextField(value = boxName.value, onValueChange = { it ->
boxName.value = it
}, label = { Text(text = "Button Name") })
}
Row(
modifier = Modifier.defaultMinSize(),
horizontalArrangement = Arrangement.Center
) {
TextField(value = boxCommand.value, onValueChange = { it ->
boxCommand.value = it
}, label = { Text(text = "Enter Command") })
}
Row(
modifier = Modifier.fillMaxWidth(),
horizontalArrangement = Arrangement.Center
) {
Button(onClick = {
close()
processBoxData(boxName, boxCommand)
}) {
Text(text = "Done")
}
Button(onClick = { close() }) {
Text(text = "Cancel")
}
}
}
}
}
}
Ниже работает
Код: Выделить всё
AnimatedVisibility(
visible = boxVisible.value,
enter = fadeIn(),
exit = fadeOut()
) {
Box(
modifier = Modifier
.fillMaxSize()
.background(color = Color(0.0f, 0f, 0f, 0.5f)),
contentAlignment = Alignment.Center
) {
ElevatedCard(
modifier = Modifier
.padding(15.dp)
.defaultMinSize()) {
Row(
modifier = Modifier.defaultMinSize(),
horizontalArrangement = Arrangement.Center
) {
TextField(value = boxName.value, onValueChange = { it ->
boxName.value = it
}, label = { Text(text = "Button Name") })
}
Row(
modifier = Modifier.defaultMinSize(),
horizontalArrangement = Arrangement.Center
) {
TextField(value = boxCommand.value, onValueChange = { it ->
boxCommand.value = it
}, label = { Text(text = "Enter Command") })
}
Row(
modifier = Modifier.fillMaxWidth(),
horizontalArrangement = Arrangement.Center
) {
Button(onClick = {
boxVisible.value = !boxVisible.value
val list = groupComponents[boxGroupIndex.value].elements
list[boxElementIndex.value].name = boxName.value
list[boxElementIndex.value].data = boxCommand.value
groupComponents[boxGroupIndex.value].copy(
elements = list
)
}) {
Text(text = "Done")
}
Button(onClick = { close() }) {
Text(text = "Cancel")
}
}
}
}
}
Я пробовал перемещать переменные внутри и из составной функции, перемещение места вызова функции, изменение параметров в составной функции. Все это приводит к одной и той же проблеме: данные изменяются по мере необходимости, но пользовательский интерфейс не перекомпоновывается.
Подробнее здесь: https://stackoverflow.com/questions/791 ... ecomposing
Мобильная версия