• Android6.0+修改通知栏与页面样式保持一致


    1.带有标题的页面

    带有标题栏的样式Theme.MaterialComponents.DayNight.DarkActionBar

    1. <style name="Theme.TIM" parent="Theme.MaterialComponents.DayNight.DarkActionBar">
    2. <!-- Primary brand color. -->
    3. <item name="colorPrimary">@color/purple_500</item>
    4. <item name="colorPrimaryVariant">@color/purple_700</item>
    5. <item name="colorOnPrimary">@color/white</item>
    6. <!-- Secondary brand color. -->
    7. <item name="colorSecondary">@color/teal_200</item>
    8. <item name="colorSecondaryVariant">@color/teal_700</item>
    9. <item name="colorOnSecondary">@color/black</item>
    10. <!-- Status bar color. -->
    11. <item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item>
    12. <!-- Customize your theme here. -->
    13. </style>

     通过修改样式

    <item name="colorPrimary">@color/white</item>
    <item name="colorPrimaryVariant">@color/white</item>
    <item name="colorOnPrimary">@color/white</item>
    
    colorPrimaryVariant属性控制通知栏的颜色,
    colorPrimary属性控制页面标题栏的颜色

     修改一致之后,通知栏的字体颜色也没了

    这时在activity中需要把通知栏的文字设置成暗色

    1. @Override
    2. protected void onCreate(Bundle savedInstanceState) {
    3. super.onCreate(savedInstanceState);
    4. setContentView(R.layout.activity_main);
    5. getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
    6. }

     2.不带标题栏的页面

    不带标题栏的页面样式Theme.MaterialComponents.DayNight.NoActionBar

    1. <style name="Theme.TIM" parent="Theme.MaterialComponents.DayNight.NoActionBar">
    2. <!-- Primary brand color. -->
    3. <item name="colorPrimary">@color/white</item>
    4. <item name="colorPrimaryVariant">@color/white</item>
    5. <item name="colorOnPrimary">@color/white</item>
    6. <!-- Secondary brand color. -->
    7. <item name="colorSecondary">@color/teal_200</item>
    8. <item name="colorSecondaryVariant">@color/teal_700</item>
    9. <item name="colorOnSecondary">@color/black</item>
    10. <!-- Status bar color. -->
    11. <item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item>
    12. <!-- Customize your theme here. -->
    13. </style>

     由于主题颜色是深色,所以通知栏的文字颜色自动设置成了白色来适应

    通过修改主题样式中的colorPrimaryVariant属性,修改通知栏的颜色

     此时主题颜色变成亮色,需要手动在activity中修改文字颜色为黑色,来适配这个主题

    1. @Override
    2. protected void onCreate(Bundle savedInstanceState) {
    3. super.onCreate(savedInstanceState);
    4. setContentView(R.layout.activity_main);
    5. getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
    6. }

    3.在代码中动态设置通知栏的颜色和通知栏文字颜色

    设置通知栏为浅色,则文字颜色设置成黑色

    1. getWindow().setStatusBarColor(getResources().getColor(R.color.white, null));
    2. getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);

    设置通知栏为深色,则文字颜色设置成白色

    1. getWindow().setStatusBarColor(getResources().getColor(R.color.black, null));
    2. getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_STABLE);

     

  • 相关阅读:
    CSS3提高: CSS3 动画
    几种swf格式视频转换器简介
    基于Java+SpringBoot+Thymeleaf+Mysql旅游景区景点售票购票系统系统设计与实现
    计算机组成原理(六)
    JavaWeb搭建学生管理系统(手把手)
    【Hack The Box】Linux练习-- Forge
    电子技术基础(三)__第7章 时序逻辑电路_第7篇之解题方法与步骤
    Java 函数式编程
    高等工程数学 —— 第四章 (2)线性方程组的迭代解法和极小化方法
    一文浅谈Mockito使用
  • 原文地址:https://blog.csdn.net/mozushixin_1/article/details/125541438