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可控制主题变化,配置设置状态栏黑白色达到预期效果。

相关推荐
赏金术士33 分钟前
Compose 教学项目
android·kotlin·compose
晓梦林39 分钟前
ximai靶场学习笔记
android·笔记·学习
十六年开源服务商5 小时前
2026服务器配置优化与WordPress运维实战指南
android·运维·服务器
音视频牛哥7 小时前
大牛直播SDK(SmartMediaKit)Android平台Unity3D RTSP/RTMP播放器集成实践
android·unity3d·rtsp播放器·rtmp播放器·unity3d rtmp播放器·安卓unity rtsp播放器·安卓unity rtmp播放器
w1wi7 小时前
安卓抓包完全指南(一):从入门到 SSL Pinning 绕过
android·网络协议·ssl
aqi009 小时前
一文理清 HarmonyOS 6.0.2 涵盖的十个升级点
android·华为·harmonyos·鸿蒙·harmony
赏金术士10 小时前
Jetpack Compose 状态提升(State Hoisting)完全指南
android·kotlin·compose
BoomHe10 小时前
git Rebase 为任意一笔提交补上 Change-Id
android·git·android studio
TDengine (老段)10 小时前
TDengine 超级表/子表/普通表 — 设计理念与内部表示
android·大数据·数据库·物联网·时序数据库·tdengine·涛思数据