Цвет строки состояния для уровня API ниже 21 не меняется

Цвет строки состояния для уровня API 21 или выше изменяется в соответствии с моим требованием, но как изменить цвет для уровня API ниже 21.

Ниже приведены скриншоты для обоих API

Уровень API 21:

Уровень API 19:

colors.xml

    <?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="colorPrimary">#3F51B5</color>
    <color name="colorPrimaryDark">#303F9F</color>
    <color name="colorAccent">#FFFFFF</color>
    <item name="b" type="color">#FF33B5E5</item>

    <item name="p" type="color">#FFAA66CC</item>

    <item name="g" type="color">#FF99CC00</item>

    <item name="o" type="color">#FFFFBB33</item>
</resources>

Style.xml

<resources>

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!-- Customize your theme here. -->

    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <item name="windowActionBarOverlay">false</item>
    <item name="windowNoTitle">true</item>
    <item name="windowActionBar">false</item>
</style>

<style name="AppTheme.NoActionBar">
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <item name="windowActionBar">false</item>
    <item name="windowNoTitle">true</item>
</style>

<style name="MyCustomTabLayout" parent="Widget.Design.TabLayout">
    <item name="tabSelectedTextColor">@color/colorAccent</item>
</style>

<style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar" />

<style name="AppTheme.PopupOverlay" parent="ThemeOverlay.AppCompat.Light" />

Вот что происходит, когда я выполняю изменения:

5 ответов

Окрашивание строки состояния не поддерживается ниже уровня API 21. Однако вы можете использовать несколько методов, с помощью которых вы можете сделать это до уровня API 19.

Добавьте это в свой файл build.gradle:

compile 'com.readystatesoftware.systembartint:systembartint:1.0.3'

В вашей деятельности перед вызовом метода setContentView этот метод:

private void initStatusBar() {
    Window window = getWindow();

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT && Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
        window.addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
        SystemBarTintManager tintManager = new SystemBarTintManager(this);
        tintManager.setStatusBarTintEnabled(true);
        tintManager.setTintColor(ContextCompat.getColor(this, R.color.primaryDark));
    }
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
        window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_STABLE | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);
        window.setStatusBarColor(Color.TRANSPARENT);
    }


}

После этого добавьте этот атрибут в макет верхнего уровня в файле activity_layout.xml:

android:fitsSystemWindows="true"

Вот как это выглядит на Lollipop и выше:

введите описание изображения здесь

а это на киткат:

введите описание изображения здесь

Поскольку в API 21 изменение цвета строки состояния не поддерживается

К вашему сведению, в API 21 не будет классов или методов по умолчанию для изменения цвета строки состояния.

Тем не менее, вы хотите реализовать ваши требования, тогда вы можете применить игру с макетом и стилем.

Создайте папку значений для версии API, т.е. values-v19

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <item name="android:windowTranslucentNavigation">false</item>
    <item name="android:windowTranslucentStatus">true</item>
    <item name="android:windowNoTitle">true</item>
</style>

Теперь нужно изменить макет.

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="moon.testwithold.MainActivity">
    <RelativeLayout
        android:id="@+id/statusbar"
        android:layout_width="match_parent"
        android:layout_height="25dp"
        android:layout_alignParentTop="true"
        android:background="@color/colorPrimaryDark" >
    </RelativeLayout>
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World!" />
</LinearLayout>

Теперь нужно изменить в основной класс

public class MainActivity extends AppCompatActivity {
    RelativeLayout statusbar;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        statusbar=(RelativeLayout)findViewById(R.id.statusbar);
        if (Build.VERSION.SDK_INT <= Build.VERSION_CODES.KITKAT)
        {
            int titleBarHeight= getStatusBarHeight();
            Log.e("TAG"," titleBarHeight "+titleBarHeight);
            LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,titleBarHeight);
            statusbar.setLayoutParams(params);
            statusbar.setVisibility(View.VISIBLE);
        }
        else
        {
            statusbar.setVisibility(View.GONE);
        }
    }
    public int getStatusBarHeight() {
        int result = 0;
        int resourceId = getResources().getIdentifier("status_bar_height", "dimen", "android");
        if (resourceId > 0) {
            result = getResources().getDimensionPixelSize(resourceId);
        }
        return result;
    }
}

Замечания:

Если вы хотите сделать умную работу, то, пожалуйста, создайте глобальный класс активности (Базовая активность) и внедрите вышеупомянутый метод в этом классе и расширьте этот класс для любой активности, чтобы вы могли выполнять умную работу и сократить кодирование.

Попробуй использовать

<item name="android:statusBarColor">@color/color_name</item>

внутри вас стиль.

Изменить цвет строки состояния для уровня API ниже 21

public void setStatusBarColor(Activity activity, int RecColor) {
        Window window = activity.getWindow();
        // clear FLAG_TRANSLUCENT_STATUS flag:
        window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
        // add FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS flag to the window
        window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
        // finally change the color
        window.setStatusBarColor(ContextCompat.getColor(activity, RecColor));
    }
Другие вопросы по тегам