How to change system navigation bar color

AndroidAndroid 5.0-Lollipop

Android Problem Overview


In guidelines of Android 5.0, the navigation bar seems customizable: http://www.google.com/design/spec/layout/structure.html#structure-system-bars

How can I change the navigation bar color? I would like to use a white style.

Screenshots: enter image description here enter image description here enter image description here enter image description here


Edit: In my resources, I tested the style:

<item name="android:navigationBarColor" tools:targetApi="21">@android:color/white</item>

But the buttons are white. I would like the same renderer as the second image.

enter image description here

Android Solutions


Solution 1 - Android

Starting from API 27, it is now possible to use the light style of the navigation bar:

<item name="android:navigationBarColor">@android:color/white</item>
<item name="android:windowLightNavigationBar">true</item>

From the documentation:

windowLightNavigationBar

> If set, the navigation bar will be drawn such that it is compatible with a light navigation bar background. > > For this to take effect, the window must be drawing the system bar > backgrounds with windowDrawsSystemBarBackgrounds and the navigation > bar must not have been requested to be translucent with > windowTranslucentNavigation. Corresponds to setting > SYSTEM_UI_FLAG_LIGHT_NAVIGATION_BAR on the decor view.

Solution 2 - Android

Use this in your Activity.

 if (android.os.Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
        getWindow().setNavigationBarColor(getResources().getColor(R.color.green));
    }

Solution 3 - Android

add this line in your v-21/style

<style name="AppTheme.NoActionBar">
    <item name="windowActionBar">false</item>
    <item name="windowNoTitle">true</item>
    <item name="android:windowDrawsSystemBarBackgrounds">true</item>
    <item name="android:statusBarColor">@android:color/transparent</item>
    <item name="android:navigationBarColor">@android:color/black</item>
</style>

Solution 4 - Android

This code changes the navigation bar color according to your screen background color:

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
            getWindow().setNavigationBarColor(ContextCompat.getColor(this, R.color.any_color));
        }

You can also use the light style for the navigation bar:

<item name="android:navigationBarColor">@android:color/white</item>

Solution 5 - Android

the navigation bar is not supposed to be colored

> When you customize the navigation and status bars, either make them both transparent or modify only the status bar. The navigation bar should remain black in all other cases.

(source https://developer.android.com/training/material/theme.html )

BUT, you can use this library to achieve what you want :) https://github.com/jgilfelt/SystemBarTint

Solution 6 - Android

if (android.os.Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
        getWindow().setNavigationBarColor(getResources().getColor(R.color.colorWhite));
        getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LIGHT_NAVIGATION_BAR); //For setting material color into black of the navigation bar
    }

Use this one if your app's API level is greater than 23

getWindow().setNavigationBarColor(ContextCompat.getColor(MainActivity.this, R.color.colorWhite));
        getWindow().getDecorView().setSystemUiVisibility(SYSTEM_UI_FLAG_LIGHT_NAVIGATION_BAR);

May this code will not work for API level 30. Because " SYSTEM_UI_FLAG_LIGHT_NAVIGATION_BAR" is deprecated in API level 30. Check this out: https://developer.android.com/reference/android/view/View#SYSTEM_UI_FLAG_LIGHT_NAVIGATION_BAR

Solution 7 - Android

You can also set light system navigation bar in API 26 programmatically:

View.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LIGHT_NAVIGATION_BAR);

Where View coluld be findViewById(android.R.id.content).

However remember that: > For this to take effect, the window must request FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS but not FLAG_TRANSLUCENT_NAVIGATION.

See documentation.

Solution 8 - Android

 getWindow().setNavigationBarColor(ContextCompat.getColor(MainActivity.this,R.color.colorPrimary)); //setting bar color   
 getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR); //additional setting items to be black if using white ui  

Solution 9 - Android

Old question. But at this time we have a direct solution. May be helpful for someone.

public static void setNavigationBarColor(Activity activity, int color, int divColor) {
    Window window= activity.getWindow();
    window.setNavigationBarColor(color);
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P) {
        window.setNavigationBarDividerColor(divColor);
    }
}

View Official Documentation

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionalexView Question on Stackoverflow
Solution 1 - AndroidEyesClearView Answer on Stackoverflow
Solution 2 - AndroidRoadiesView Answer on Stackoverflow
Solution 3 - AndroidHuseyinView Answer on Stackoverflow
Solution 4 - AndroidRahulView Answer on Stackoverflow
Solution 5 - AndroidPierfrancesco SoffrittiView Answer on Stackoverflow
Solution 6 - AndroidShawon ShamsView Answer on Stackoverflow
Solution 7 - AndroidwrozwadView Answer on Stackoverflow
Solution 8 - Androidconrad wawireView Answer on Stackoverflow
Solution 9 - AndroidMahbubur Rahman KhanView Answer on Stackoverflow