реализация темной темы в моем приложении;другой цвет отображается на панели инструментов различной активности - PullRequest
0 голосов
/ 28 октября 2019

Я хотел реализовать темную тему в своем приложении;у него есть панель инструментов в основной активности и панель действий в другой деятельности. Я реализовал темную тему в файле values ​​/ styles.xml, как показано ниже:

<resources>
    <style name="AppTheme" parent="Theme.MaterialComponents">
        <item name="colorPrimary">@color/primary_material_dark</item>
        <item name="colorPrimaryDark">@color/primary_dark_material_dark</item>
        <item name="colorAccent">@color/material_deep_teal_200</item>
    </style>

    <style name="AppTheme.NoActionBar">
        <item name="windowActionBar">false</item>
        <item name="windowNoTitle">true</item>
    </style>

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

После этого мое приложение превратилось в темную тему, но цвет панели инструментов основного действия различен, а цвет панели действий другого действияразные. И при переходе к другому виду деятельности также происходит некоторое мигание.

В моей основной деятельности есть просмотр карт, выполненный переработчиком;Я хотел реализовать темную тему, как на этой картинке. Dark Theme

Я не знаю, почему цвет панели инструментов меняется при переходе от основного занятия к другому занятию (другое занятие имеет панель действий), а фон мигает при переходе от одногодеятельность к другому.

Я также хочу установить цвет всего фона макета цвета карты, как показано на рисунке. Я пытался сделать это так много раз, но этого не происходит, фон мигает: (

Кстати, это xml (app_bar_main.xml) моей панели инструментов:

<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout
    ..
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <com.google.android.material.appbar.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/AppTheme.AppBarOverlay">

        <androidx.appcompat.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
             />

    </com.google.android.material.appbar.AppBarLayout>

    <include layout="@layout/content_main" />

    <com.google.android.material.floatingactionbutton.FloatingActionButton.../>

</androidx.coordinatorlayout.widget.CoordinatorLayout>

1 Ответ

0 голосов
/ 29 октября 2019

Использование:

<com.google.android.material.appbar.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        style="@style/MyAppBar"
        ..>

, где:

<style name="MyAppBar" parent="@style/Widget.Design.AppBarLayout">
    <item name="android:background">?attr/colorPrimary</item>
    <item name="android:elevation">xxdp</item>
    ...
</style>
...