android 状态栏一体化 fragment,单Activity多Fragment动态修改状态栏颜色功能

目录介绍

1.关于如何集成

2.关于如何使用

3.关于鸣谢

4.关于版本更新说明

5.关于其他介绍

0.说明

状态栏工具类,应该可以满足绝大多数的使用场景。具体可以参考代码案例,欢迎star!!

1.关于如何集成

在gradle中添加:compile 'cn.yc:YCStatusBarLib:1.3.1'

2.关于如何使用

2.1.1 DrawerLayout设置状态栏

//为DrawerLayout 布局设置状态栏颜色,纯色

StatusBarUtils.setColorNoTranslucentForDrawerLayout(this, drawerLayout,getResources().getColor(R.color.colorTheme));

//为DrawerLayout 布局设置状态栏变色,也就是加上透明度

StatusBarUtils.setColorForDrawerLayout(this, drawerLayout,getResources().getColor(R.color.colorTheme), 0);

2.1.2 设置状态栏颜色

YCAppBar.setStatusBarColor(this, ContextCompat.getColor(this, R.color.colorAccent));

2.1.3 设置状态栏和toolbar颜色

注意,如果是设置白色的话,则需要单独设置状态栏字体的颜色,否则看不见

如果要设置状态栏为白色:则直接可以使用2.7中的方法

YCAppBar.setStatusBarColor(this, ContextCompat.getColor(this, R.color.colorAccent));

2.1.4 设置状态栏透明

YCAppBar.translucentStatusBar(this, true);

2.1.5 设置状态栏coordinatorLayout颜色

YCAppBar.setStatusBarColor(this, ContextCompat.getColor(this, R.color.colorPrimary));

2.1.6 设置状态栏coordinatorLayout颜色透明

YCAppBar.setStatusBarColorForCollapsingToolbar(this, mAppBarLayout, collapsingToolbarLayout, toolbar, ContextCompat.getColor(this, R.color.colorPrimary));

2.1.7 设置状态栏颜色为白色

YCAppBar.setStatusBarLightMode(this, Color.WHITE);

2.1.8 设置状态栏和toolbar颜色为白色

YCAppBar.setStatusBarLightMode(this, Color.WHITE);

2.1.9 设置状态栏和coordinatorLayout为白色

YCAppBar.setStatusBarLightForCollapsingToolbar(this, mAppBarLayout, collapsingToolbarLayout, toolbar, Color.WHITE);

2.2.0 单Activity多Fragment动态修改状态栏颜色

如果是单Activity多Fragment,由Fragment控制状态栏颜色的应用,有两种方案:

1.由Activity控制状态栏背景颜色和字体颜色,提供方法供Fragment调用即可。

2.首先设置Activity侵入状态栏,并设置状态栏为透明色,相当于隐藏Activity的状态栏,

然后在BaseFragment中封装状态栏,由Fragment控制自己的颜色即可;

但是状态栏字体颜色还是需要通过Activity控制。

//例如,ViewPager+TabLayout+Fragment中,很常见

@Override

public void onPageSelected(int position) {

switch (position){

case 0:

//设置状态栏为黑色

YCAppBar.setStatusBarColor(StatusBarFragmentActivity.this,

ContextCompat.getColor(StatusBarFragmentActivity.this,

R.color.colorTheme));

break;

case 1:

//设置状态栏为红色

YCAppBar.setStatusBarColor(StatusBarFragmentActivity.this,

ContextCompat.getColor(StatusBarFragmentActivity.this,

R.color.colorAccent));

break;

case 2:

//设置状态栏为蓝色

YCAppBar.setStatusBarColor(StatusBarFragmentActivity.this,

ContextCompat.getColor(StatusBarFragmentActivity.this,

R.color.colorPrimary));

break;

case 3:

//设置状态栏为透明,相当于隐藏状态栏,也称之为沉浸式状态栏

YCAppBar.translucentStatusBar(StatusBarFragmentActivity.this,

true);

break;

case 4:

//设置状态栏为白色

YCAppBar.setStatusBarColor(StatusBarFragmentActivity.this,

ContextCompat.getColor(StatusBarFragmentActivity.this,

R.color.white));

//状态栏亮色模式,设置状态栏黑色文字、图标

StatusBarUtils.StatusBarLightMode(StatusBarFragmentActivity.this);

break;

}

}

2.2.1 可以自由设置状态栏中的字体,图标颜色

支持类型,1:MIUUI 2:Flyme 3:android6.0

//状态栏亮色模式,设置状态栏黑色文字、图标

StatusBarUtils.StatusBarLightMode(StatusBarFragmentActivity.this);

3.关于鸣谢

关于状态栏,采用的是拿来主义,是经过阅读一些项目慢慢总结而来的。

非常使用,具体的用法都已经整理成demo,欢迎直接看代码,如果可以麻烦star!

感谢开源前辈们的无私奉献……

4.关于版本更新说明

v0.0 更新于2016年3月9日

v1.0 更新于2017年9月8日

v1.1 更新于2017年12月5日

v1.3 更新于2018年3月16日

v1.3.1 更新于2018年9月1日

添加了单Activity多Fragment动态修改状态栏颜色功能

5.关于其他介绍

关于我的博客

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
A powerful library that manage Fragment for Android!为"Activity + 多Fragment","多模块ActivityFragment"架构而生,简化开发,轻松解决动画、嵌套、事务相关等问题。为了更好的使用和了解该库,推荐阅读下面的文章:Fragment全解析系列(一):那些年踩过的坑Fragment全解析系列(二):正确的使用姿势Demo演示:均为ActivityFragment,第一个为简流式demo,第二个为仿微信交互的demo(全页面支持滑动退出),第三个为仿知乎交互的复杂嵌套demo下载APK   特性1、可以快速开发出各种嵌套设计的Fragment App2、悬浮球/摇一摇实时查看Fragment的栈视图Dialog,降低开发难度3、增加启动模式、startForResult等类似Activity方法4、类似Android事件分发机制的Fragment回退方法:onBackPressedSupport(),轻松为每个Fragment实现Back按键事件5、提供onSupportVisible()等生命周期方法,简化嵌套Fragment的开发过程; 提供统一的onLazyInitView()懒加载方法6、提供 Fragment转场动画 系列解决方案,动态更换动画7、提供Activity作用域的EventBus辅助类,Fragment通信更简、独立(需要使用EventBusActivityScope库)8、支持SwipeBack滑动边缘退出(需要使用Fragmentation_SwipeBack库)      如何使用1. 项目下app的build.gradle中依赖:// appcompat-v7包是必须的,v1.1.9兼容v4-27.0.0 compile 'me.yokeyword:fragmentation:1.1.9' // 如果不想继承SupportActivity/Fragment,自己定制Support,可仅依赖: // compile 'me.yokeyword:fragmentation-core:1.1.9' // 如果想使用SwipeBack 滑动边缘退出Fragment/Activity功能,完整的添加规则如下: compile 'me.yokeyword:fragmentation:1.1.9' // swipeback基于fragmentation, 如果是自定制SupportActivity/Fragment,则参照SwipeBackActivity/Fragment实现即可 compile 'me.yokeyword:fragmentation-swipeback:1.1.9' // Activity作用域的EventBus,更安全,可有效避免after onSavenInstanceState()异常 compile 'me.yokeyword:eventbus-activity-scope:1.1.0' // Your EventBus's version compile 'org.greenrobot:eventbus:{version}'2. Activity继承SupportActivity:// v1.0.0开始,不强制继承SupportActivity,可使用接口+委托形式来实现自己的SupportActivity public class MainActivity extends SupportActivity {     @Override     protected void onCreate(Bundle savedInstanceState) {         super.onCreate(savedInstanceState);         setContentView(...);         // 建议在Application里初始化         Fragmentation.builder()              // 显示悬浮球 ; 其他Mode:SHAKE: 摇一摇唤出   NONE:隐藏              .stackViewMode(Fragmentation.BUBBLE)              .debug(BuildConfig.DEBUG)              ... // 更多查看wiki或demo              .install();         if (findFragment(HomeFragment.class) == null)

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值