首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Jetpack Compose BottomBar在底部导航

Jetpack Compose BottomBar在底部导航
EN

Stack Overflow用户
提问于 2022-07-12 14:56:59
回答 2查看 430关注 0票数 0

我在Jetpack撰写中通过Scaffold实现了BottomBar。

它可以很好的工作在智能手机与手势导航。但是当启用旧版底部按钮时,重叠的是我的BottomBar。

屏幕截图

我的代码:

代码语言:javascript
复制
Scaffold(
        bottomBar = {
            BottomMenu()
        }
    ) { innerPadding ->
        Surface(
            color = AppTheme.colors.background.primary,
            modifier = Modifier
                .fillMaxSize()
        ) {
            Column(
                modifier = Modifier
                    .verticalScroll(rememberScrollState())
                    .padding(bottom = innerPadding.calculateBottomPadding())
            ) {
                MyContent()
            }
        }
    }

BottomMenu():

代码语言:javascript
复制
Column(
        modifier = Modifier
            .fillMaxWidth()
            .background(AppTheme.colors.background.secondary)
    ) {
        Box(
            modifier = Modifier
                .fillMaxWidth()
                .height(1.dp)
                .background(AppTheme.colors.background.primary)
        )
        Row(
            modifier = Modifier
                .fillMaxWidth()
                .padding(top = 8.dp),
        ) {
    ...
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-07-13 03:43:54

使用Compose的BottomAppBar作为Column()的父级,因为它具有内置的属性来显示添加到系统导航抽屉的视图。示例:

代码语言:javascript
复制
    BottomAppBar(
        cutoutShape = RoundedCorner(10.dp),
        elevation = 0.dp,
        contentColor = "bottomContentColor",
        backgroundColor = "bottomBarColor"
    ) {
        Column(
            modifier = Modifier
                .fillMaxWidth()
                .background(AppTheme.colors.background.secondary)
        ) {
            Box(
                modifier = Modifier
                    .fillMaxWidth()
                    .height(1.dp)
                    .background(AppTheme.colors.background.primary)
            )
            Row(
                modifier = Modifier
                    .fillMaxWidth()
                    .padding(top = 8.dp),
            ) {

            }
        }.....
    }

样本图像:-

票数 0
EN

Stack Overflow用户

发布于 2022-10-15 12:19:38

您可以将Modifier.navigationBarsPadding()用于Scaffold或所需的任何匹配父组件。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72954383

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档