gpt4 book ai didi

android - 如何控制 Jetpack Compose 中的 DropDownMenu 位置

转载 作者:行者123 更新时间:2023-12-04 23:45:49 64 4
gpt4 key购买 nike

我有一排文本在开头对齐,图像在结尾对齐。当我按下图像时,我正在显示一个 DropdownMenu,但它出现在行的开头,我希望它出现在行的末尾。
我正在尝试在修改器组件中使用 Alignment.centerEnd 但不起作用。
如何使弹出窗口出现在行尾?

@Composable
fun DropdownDemo(currentItem: CartListItems) {
var expanded by remember { mutableStateOf(false) }
Box(modifier = Modifier
.fillMaxWidth()) {
Text(modifier = Modifier.align(Alignment.TopStart),
text = currentItem.type,
color = colorResource(id = R.color.app_grey_dark),
fontSize = 12.sp)
Image(painter = painterResource(R.drawable.three_dots),
contentDescription = "more options button",
Modifier
.padding(top = 5.dp, bottom = 5.dp, start = 5.dp)
.align(Alignment.CenterEnd)
.width(24.dp)
.height(6.75.dp)
.clickable(indication = null,
interactionSource = remember { MutableInteractionSource() },
onClick = {
expanded = true
}))
DropdownMenu(
expanded = expanded,
onDismissRequest = { expanded = false },
modifier = Modifier
.background(
Color.LightGray
).align(Alignment.CenterEnd),
) {
DropdownMenuItem(onClick = { expanded = false }) {
Text("Delete")
}
DropdownMenuItem(onClick = { expanded = false }) {
Text("Save")
}
}
}
}

最佳答案

documentation说:

A DropdownMenu behaves similarly to a Popup, and will use the position of the parent layout to position itself on screen.


你需要把 DropdownMenuBox 中的调用者 View 一起.在这种情况下 DropdownMenu将出现在调用者 View 下。
var expanded by remember { mutableStateOf(false) }
Column {
Text("Some text")
Box {
Image(
painter = painterResource(R.drawable.test),
contentDescription = "more options button",
modifier = Modifier
.clickable {
expanded = true
}
)
DropdownMenu(
expanded = expanded,
onDismissRequest = { expanded = false },
) {
DropdownMenuItem(onClick = { expanded = false }) {
Text("Delete")
}
DropdownMenuItem(onClick = { expanded = false }) {
Text("Save")
}
}
}
}

关于android - 如何控制 Jetpack Compose 中的 DropDownMenu 位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68728375/

64 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com