• 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);

     

  • 相关阅读:
    根据经纬度查地址
    Business eXtreme 5 企业级报表和数据分析工具
    【踩坑】parallel并发流导致数据异常
    说说MQ在你项目中的应用(二)商品支付
    iOS代码混淆-从入门到放弃
    【Python】第六课 字典和集合
    SpringCloud接入nacos配置中心
    5.OsgEarth加载地形
    [开发工具]svn
    前端数据库大批量存,indexdDB使用
  • 原文地址:https://blog.csdn.net/mozushixin_1/article/details/125541438