Skip to content

A Jetpack Compose library for Android with easy-to-use utilities to tweak the color, scrim, behavior, and visibility of the System UI bars.

License

Notifications You must be signed in to change notification settings

stoyan-vuchev/system-ui-bars-tweaker

Repository files navigation

API

A Jetpack Compose library for Android with easy-to-use utilities to tweak the color, behavior, and visibility of the System UI bars.

Table of Contents


Introduction

  • On August 24th, 2023, the Accompanist System UI Controller library was deprecated in favor of the new Activity.enableEdgeToEdge method available in androidx.activity version 1.8.0-alpha03 and later.

  • The new method only supports enabling Edge-To-Edge functionality and applying light/dark scrim to the System UI bars. Therefore, losing the easy-to-use utilities for tweaking the color, behavior, and visibility. That's the main reason I've decided to create the System UI Bars Tweaker library.

  • This library provides all the Accompanist System UI Controller functionality out of the box.


Usage

Articles Example GIF Photos Example GIF

It's important to note a few things

  • ⚠️ Starting with Android 15 (API 35+), the system bars color is transparent by default and can't be changed. Therefore, the functionality for changing the system bars color and applying a custom scrim will no longer work. Older versions are intact and they can still utilize the functionality.

  • ✨ The library is written with efficiency and flexibility in mind, simply by following an approach based on a Producer and Consumer, which integrates really well with Compose.

  • ✅ Transparent status bar & navigation bar (without a scrim for gesture navigation) are enabled by default, however, to enable Edge-To-Edge, make sure to call the enableEdgeToEdge() function in the activity onCreate().

// ...
import androidx.activity.enableEdgeToEdge

class MainActivity : ComponentActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
      
        // Enable Edge-To-Edge.
        enableEdgeToEdge()
      
        setContent { 
            // ...
        }
      
    }

}
  • It's recommended to use a single top-level SystemUIBarsTweaker instance per activity/dialog Window and consume it down the composition.

  • Here is an example by wrapping a Material3 app theme inside a ProvideSystemUIBarsTweaker composable (a Producer) and declaring a tweaker variable by using the LocalSystemUIBarsTweaker key (a Consumer). You can declare more than one variable anywhere down the composition, as long as there is a Producer to provide the top-level instance.

@Composable
fun ApplicationTheme(
    darkTheme: Boolean = isSystemInDarkTheme(),
    // ...
) {

    // ...

    ProvideSystemUIBarsTweaker {

        val tweaker = LocalSystemUIBarsTweaker.current

        DisposableEffect(tweaker, darkTheme) {

            // Update all of the system bar colors to be transparent,
            // use dark icons if we're in light theme,
            // and apply scrim to the navigation bar (only for button navigation mode).

            tweaker.tweakSystemBarsStyle(
                statusBarStyle = SystemBarStyle(
                    color = Color.Transparent,
                    darkIcons = !darkTheme,
                    scrimStyle = ScrimStyle.None
                ),
                navigationBarStyle = SystemBarStyle(
                    color = Color.Transparent,
                    darkIcons = !darkTheme,
                    scrimStyle = if (!tweaker.isGestureNavigationEnabled) ScrimStyle.System 
                    else ScrimStyle.None
                )
            )

            // tweakStatusBarStyle() and tweakNavigationBarStyle() also exist.

            // tweakStatusBarVisibility(), tweakNavigationBarVisibility(), and tweakSystemBarsBehavior() as well.

             onDispose {}
        }

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

    }

}
  • If you don't want to use the Producer and Consumer approach, you can simply create an instance using a rememberSystemUIBarsTweaker() composable.
val tweaker = rememberSystemUIBarsTweaker()

Gradle Kotlin DSL Setup

Step 1

  • Add the Jitpack maven repository inside the dependencyResolutionManagement block of the settings.gradle file if you don't have it already.
dependencyResolutionManagement {
    repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
    repositories {
        google()
        mavenCentral()
        maven(url = "https://jitpack.io/") // this one
    }
}

Step 2

  • Add the dependency in your module build.gradle.kts file.
  • Latest version:
implementation("com.github.stoyan-vuchev:system-ui-bars-tweaker:<version>")
  • Or if you're using a version catalog (e.g. libs.versions.toml), declare it there.
[versions]
systemUIBarsTweaker = "<version>"

[libraries]
systemUIBarsTweaker = { group = "com.github.stoyan-vuchev", name = "system-ui-bars-tweaker", version.ref = "systemUIBarsTweaker" }
  • Then include the dependency in your module build.gradle.kts file.
implementation(libs.systemUIBarsTweaker)

Step 3

  • Sync and rebuild the project. ✅


Gradle Groovy Setup

Step 1

  • Add the Jitpack maven repository inside the dependencyResolutionManagement block of the settings.gradle file if you don't have it already.
dependencyResolutionManagement {
    repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
    repositories {
        google()
        mavenCentral()
        maven { url 'https://jitpack.io' } // this one
    }
}

Step 2

  • Add the dependency in your module build.gradle file.
  • Latest version:
implementation 'com.github.stoyan-vuchev:system-ui-bars-tweaker:<version>'

Step 3

  • Sync and rebuild the project. ✅


Notice

This project includes software components that are subject to the Apache License, Version 2.0.

Portions of this software are copyright 2022 The Android Open Source Project.

The majority of the code in this project has been extensively modified and adapted to suit the specific requirements and functionality of this project.

For more information, please refer to the NOTICE file.

Attributions:

License

This project is open source and licensed under the Apache License, Version 2.0

Contact

Created by @stoyan-vuchev
E-mail - [email protected]