android compose ModalBottomSheet 使用

android compose ModalBottomSheet 使用, ModalBottomSheet从屏幕底部弹出一个可交互的面板

复制代码
/**
 * Author : wn
 * Email : maoning20080809@163.com
 * Date : 2026/1/3 22:55
 * Description : ModalBottomSheet从屏幕底部弹出一个可交互的面板
 */
class ModalBottomSheetActivity : ComponentActivity(){

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

        setContent {
            testModalBottomSheet()
        }

    }

    /**
     * 当 showBottomSheet 状态改变时(点击关闭按钮设为 false)
     * 整个 testModalBottomSheet 函数会重新执行(重组)
     */
    @OptIn(ExperimentalMaterial3Api::class)
    @Preview
    @Composable
    private fun testModalBottomSheet(){
        var bottomSheetState = rememberModalBottomSheetState()
        var showBottomSheet by remember { mutableStateOf(false) }

        Button(onClick = {
            showBottomSheet = true
        }) {
            Text(text = "显示底部窗口")
        }
        Toast.makeText(this, "显示", Toast.LENGTH_LONG).show()
        if(showBottomSheet){
            ModalBottomSheet(
                onDismissRequest = {
                    showBottomSheet = false
                },
                sheetState =  bottomSheetState
            ) {
                //弹窗内容
                Column(modifier = Modifier.fillMaxWidth().navigationBarsPadding().padding(56.dp)){
                    Text(text = "标题", style = MaterialTheme.typography.headlineSmall)
                    Spacer(modifier = Modifier.height(16.dp))
                    Text(text = "这是底部弹出的内容", style = MaterialTheme.typography.bodyMedium)
                    Spacer(modifier = Modifier.height(24.dp))
                    Button(onClick = {
                        showBottomSheet = false
                    }, modifier = Modifier.fillMaxWidth()) {
                        Text("关闭")
                    }
                }
            }
        }
    }
}
相关推荐
Tiramisu20231 小时前
【Android】Android开发
android
是三好1 小时前
SQL 性能分析及优化
android·数据库·sql
我命由我123452 小时前
Android Jetpack Compose - enableEdgeToEdge 函数、MaterialTheme 函数、remember 函数
android·java·java-ee·kotlin·android studio·android jetpack·android-studio
2501_915921433 小时前
没有 iOS 源码的前提下如何进行应用混淆,源码混淆失效后的替代
android·ios·小程序·https·uni-app·iphone·webview
林栩link3 小时前
【车载Android】多媒体开发入门(上) - MediaSession
android·android jetpack
GoldenPlayer3 小时前
OKHTTP连接保持
android
我有与与症3 小时前
用 KuiklyUI Canvas 打造天气预测图表
android
冬奇Lab3 小时前
稳定性性能系列之八——系统性能分析基础:Systrace与Perfetto入门
android·性能优化
程序员码歌3 小时前
短思考第268天,自媒体路上的4大坑点,很多人都踩过
android·前端·ai编程
消失的旧时光-19435 小时前
从 Android 组件化到 Flutter 组件化
android·flutter·架构