compose——侧边栏

效果图:

依赖引入:

Kotlin 复制代码
implementation 'com.google.android.material:material:1.5.0'

代码如下:

Kotlin 复制代码
class MainActivity : ComponentActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContent {
            ComposedrawerTheme {
                Surface(
                    modifier = Modifier.fillMaxSize(),
                    color = MaterialTheme.colors.background
                ) {
                    MainPage()
                }
            }
        }
    }
}

@SuppressLint("UnusedMaterialScaffoldPaddingParameter")
@Composable
fun MainPage() {
    val scaffoldState = rememberScaffoldState()
    val coroutineScope = rememberCoroutineScope()// 定义协程作用域

    Scaffold(
        topBar = {
            TopAppBar(
                navigationIcon = {
                    IconButton(
                        onClick = {
                            coroutineScope.launch {
                                scaffoldState.drawerState.open()
                            }
                        }
                    ) {
                        Icon(Icons.Filled.Menu, null)
                    }
                },
                title = {
                    Text("首页")
                },
                actions = {
                    IconButton(
                        onClick = {}
                    ) {
                        Icon(Icons.Filled.Share, null)
                    }
                    IconButton(
                        onClick = {}
                    ) {
                        Icon(Icons.Filled.Settings, null)
                    }
                },
            )
        },
        drawerContent = { DrawerContent() },
        drawerGesturesEnabled = true,
        scaffoldState = scaffoldState,
    ) {

    }
}

@Composable
fun DrawerContent() {
    Text(text = "DrawerContent")
}
相关推荐
alexhilton10 分钟前
使用FunctionGemma进行设备端函数调用
android·kotlin·android jetpack
冬奇Lab3 小时前
InputManagerService:输入事件分发与ANR机制
android·源码阅读
张小潇6 小时前
AOSP15 Input专题InputManager源码分析
android·操作系统
RdoZam8 小时前
Android-封装基类Activity\Fragment,从0到1记录
android·kotlin
奥陌陌14 小时前
android 打印函数调用堆栈
android
用户9851200358314 小时前
Compose Navigation 3 深度解析(二):基础用法
android·android jetpack
恋猫de小郭14 小时前
Android 官方正式官宣 AI 支持 AppFunctions ,Android 官方 MCP 和系统级 OpenClaw 雏形
android·前端·flutter
黄林晴15 小时前
Android 17 Beta 2,隐私这把锁又拧紧了
android
Kapaseker15 小时前
研究表明,开发者对Kotlin集合的了解不到 20%
android·kotlin
bqliang15 小时前
Compose 媒体查询 (Media Query API) 🖱️👇🕹️
android·android jetpack