android compose DropdownMenu 菜单项列表 使用

android compose DropdownMenu 菜单项列表 使用

复制代码
/**
 * Author : wn
 * Email : maoning20080809@163.com
 * Date : 2026/1/7 20:33
 * Description : 菜单项列表
 */
class DropdownMenuActivity : ComponentActivity(){

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

        setContent {
            testDropdownMenu()
        }
    }

    @Preview
    @Composable
    private fun testDropdownMenu() {
        var expanded by remember { mutableStateOf(false) }
        var items = listOf("菜单1", "菜单2", "菜单3")
        var selectedIndex by remember { mutableStateOf(0) }

        Column(
            modifier = Modifier.fillMaxSize(),
            horizontalAlignment = Alignment.CenterHorizontally
        ) {
            Text(text = "DropdownMenu菜单项列表")

            Spacer(modifier = Modifier.height(20.dp))

            Box(
                modifier = Modifier.fillMaxWidth(),
                contentAlignment = Alignment.Center
            ) {
                // 将 Button 和 DropdownMenu 放在同一个 Box 中
                Box {
                    Button(onClick = {
                        expanded = true
                    }) {
                        Text(text = items[selectedIndex])
                    }

                    // DropdownMenu 默认会锚定到调用它的位置
                    // 这里它会在 Button 的位置弹出
                    DropdownMenu(
                        expanded = expanded,
                        onDismissRequest = { expanded = false },
                        offset = DpOffset(x = 60.dp, y = 0.dp) // 向右偏移 60dp(大约在右下角)
                    ) {
                        items.forEachIndexed { index, label ->
                            DropdownMenuItem(
                                text = { Text(text = label) },
                                onClick = {
                                    selectedIndex = index
                                    expanded = false
                                }
                            )
                        }
                    }
                }
            }
        }
    }
}
相关推荐
程序员清洒2 小时前
Flutter for OpenHarmony:GridView — 网格布局实现
android·前端·学习·flutter·华为
running up that hill3 小时前
Android的线性布局
android
m0_748229993 小时前
Laravel9.x核心特性全解析
android
2603_949462105 小时前
Flutter for OpenHarmony社团管理App实战:意见反馈实现
android·flutter
错把套路当深情5 小时前
android两种渠道支持一键打包 + 随意组合各种渠道
android
彬sir哥6 小时前
android studio如何把.gradle从C盘移到D盘
android·gradle·maven·android studio
、BeYourself8 小时前
TabLayout 与 ViewPager2 的基本使用
android·android-studio
南村群童欺我老无力.8 小时前
Flutter 框架跨平台鸿蒙开发 - 城市文创打卡:探索城市文化创意之旅
android·flutter·华为·harmonyos
Madison-No78 小时前
【Linux】文件操作&&重定向原理
android·linux·运维
2603_949462109 小时前
Flutter for OpenHarmony社团管理App实战:消息中心实现
android·javascript·flutter