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

相关推荐
叶羽西3 小时前
Android15系统中(娱乐框架和车机框架)中对摄像头的朝向是怎么定义的
android
Java小白中的菜鸟3 小时前
安卓studio链接夜神模拟器的一些问题
android
莫比乌斯环3 小时前
【Android技能点】深入解析 Android 中 Handler、Looper 和 Message 的关系及全局监听方案
android·消息队列
编程之路从0到13 小时前
React Native新架构之Android端初始化源码分析
android·react native·源码阅读
行稳方能走远3 小时前
Android java 学习笔记2
android·java
编程之路从0到14 小时前
React Native 之Android端 Bolts库
android·前端·react native
爬山算法4 小时前
Hibernate(38)如何在Hibernate中配置乐观锁?
android·java·hibernate
行稳方能走远4 小时前
Android java 学习笔记 1
android·java