Android状态栏文字图标设置失效

一、背景

今天无意中发现以前常用的com.githang.statusbar.StatusBarCompat设置状态栏文字颜色竟然失效了,经过排查发现Activity启用了enableEdgeToEdge之后就失效,去除enableEdgeToEdge就生效了。

为了适应新的Compose界面布局进行了各种尝试,最后按照一下步骤解决问题。

二、步骤

设置Compose主体

使用到Scaffold的情况下,在Scaffold外层添加MaterialTheme主题,对主题进行colorScheme定义,由外部控制Scaffold颜色变化。

动态控制状态栏颜色

复制代码
WindowCompat.getInsetsController(window, window.decorView).isAppearanceLightStatusBars = it

主题

复制代码
private val DarkColorScheme = darkColorScheme(
    primary = Purple80,
    secondary = PurpleGrey80,
    tertiary = Pink80
)

private val LightColorScheme = lightColorScheme(
    primary = Purple40,
    secondary = PurpleGrey40,
    tertiary = Pink40

    /* Other default colors to override
    background = Color(0xFFFFFBFE),
    surface = Color(0xFFFFFBFE),
    onPrimary = Color.White,
    onSecondary = Color.White,
    onTertiary = Color.White,
    onBackground = Color(0xFF1C1B1F),
    onSurface = Color(0xFF1C1B1F),
    */
)

@Composable
fun CclxmpaasguideTheme(
    darkTheme: Boolean = isSystemInDarkTheme(),
    // Dynamic color is available on Android 12+
    dynamicColor: Boolean = true,
    content: @Composable () -> Unit
) {
    val colorScheme = when {
        dynamicColor && Build.VERSION.SDK_INT >= Build.VERSION_CODES.S -> {
            val context = LocalContext.current
            if (darkTheme) dynamicDarkColorScheme(context) else dynamicLightColorScheme(context)
        }

        darkTheme -> DarkColorScheme
        else -> LightColorScheme
    }

    MaterialTheme(
        colorScheme = colorScheme,
        typography = Typography,
        content = content
    )
}

Scaffold

复制代码
CclxmpaasguideTheme(!isLight) {
        Scaffold(topBar = {
            CenterAlignedTopAppBar(title = {
                Text("开发调试")
            }, navigationIcon = {
                navigateBack?.let {
                    IconButton(onClick = it) {
                        Icon(imageVector = Icons.AutoMirrored.Filled.ArrowBack, null)
                    }
                }
            })
        }, containerColor = Color.White, content = { paddingValues ->
            Box(modifier = Modifier.padding(paddingValues)) {
          }
        })
    }

动态设置isLight可控制主题变化,配置设置状态栏黑白色达到预期效果。

相关推荐
赶路人儿17 分钟前
常见的mcp配置
android·adb
符哥200828 分钟前
充电桩 WiFi 局域网配网(Android/Kotlin)流程、指令及实例说明文档
android·开发语言·kotlin
没有了遇见1 小时前
Android 项目架构之<用户信息模块>
android
Georgewu3 小时前
如何判断应用在鸿蒙卓易通或者出境易环境下?
android·harmonyos
localbob3 小时前
Pico 4XVR 1.10.13安装包下载与安装教程 ico 4XVR最新版下载、4XVR 1.10.13 APK安装包、Pico VR看电影软件、4XVR完整版安装教程、Pico 4播放器推荐、V
android·vr·vr播放器·vr眼镜播放器下载·pico 4xvr·4xvr下载·pico 4xvr最新版安装包
峥嵘life4 小时前
Android16 EDLA【CTS】CtsConnectivityMultiDevicesTestCases存在fail项
android·学习
大傻^4 小时前
SpringAI2.0 Null Safety 实战:JSpecify 注解体系与 Kotlin 互操作
android·开发语言·人工智能·kotlin·springai
游戏开发爱好者84 小时前
React Native iOS 代码如何加密,JS 打包 和 IPA 混淆
android·javascript·react native·ios·小程序·uni-app·iphone
kcuwu.4 小时前
Python判断及循环
android·java·python
轩情吖4 小时前
MySQL之索引
android·数据库·mysql·b+树·索引·page·