【发布时间】:2021-12-23 12:44:57
【问题描述】:
我正在创建一个下拉菜单,其中的项目包含一个文本元素和一个图标(中间有一个分隔符);但只有第一个文本完全显示。该图标仅在有其他项目占用更多空间时可见。
@Preview(showSystemUi = true)
@Composable
fun MyScreen() {
Box(Modifier.fillMaxSize(), Alignment.Center) {
Box() {
var expanded by remember { mutableStateOf(false) }
IconButton(onClick = { expanded = !expanded }) {
Icon(imageVector = Icons.Default.MoreVert, contentDescription = null)
}
DropdownMenu(expanded = expanded, onDismissRequest = { expanded = false }) {
MyMenuItem("item 1") // Icon visible
MyMenuItem("item 2") // Icon visible
MyMenuItem("item 3 long text") // Icon width shrunk to 0
MyMenuItem("item 4 long te") // Icon visible but shrunk
}
}
}
}
@Composable
fun MyMenuItem(text: String) {
DropdownMenuItem(onClick = { }) {
Text(text)
Spacer(modifier = Modifier.weight(1f))
Icon(imageVector = Icons.Default.Check, contentDescription = null) // <-- Icon
}
}
注意:
- 我也尝试使用
Row()和Surface()代替DropdownMenuItem(),但结果相似。 - 为
MyMenuItem()作品提供宽度;但我希望它根据内容自动调整大小。
【问题讨论】:
标签: android kotlin android-jetpack-compose android-jetpack