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

     

  • 相关阅读:
    javaWeb蛋糕商城(前后台)
    vue面试题4
    KubeEdge设备接入的mqtt调试
    微信小程序进阶——会议OA其他界面
    思腾云计算
    Springboot晋韵戏剧点播网站毕业设计源码112304
    【Rust日报】2023-10-10 使用 Cackle 抵御 Rust 供应链攻击
    【云原生之Docker实战】使用Docker部署Solo个人博客站点
    讯飞AI算法挑战大赛-校招简历信息完整性检测挑战赛-三等奖方案
    微信小程序盲盒系统源码 带教程
  • 原文地址:https://blog.csdn.net/mozushixin_1/article/details/125541438