您的位置:首页 > 移动开发 > Android开发

android 玩转状态栏之透明/深色/浅色模式间相互切换

2017-03-05 16:48 615 查看
先介绍下需求背景:

先看设计稿





这是设计要求的交互效果,默认进入页面时是透明状态栏+白色状态栏文字. 往下滑动的时候状态栏与标题栏渐变为白底黑字.往上滑动时又恢复成透明+白字.

标题栏渐变那个需求我另开个文章说,这里就只讲下状态栏的变色.

首先看需求第一点,是透明状态栏,这个很简单.直接贴代码.

在onCreate里调用下面方法,根据系统版本改变状态栏

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { // 5.0 以上全透明状态栏
//取消设置透明状态栏,使 ContentView 内容不再覆盖状态栏 加下面几句可以去除透明状态栏的灰色阴影,实现纯透明
window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
//需要设置这个 flag 才能调用 setStatusBarColor 来设置状态栏颜色
window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
window.getDecorView().setSystemUiVisibility(
View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);
//6.0 以上可以设置状态栏的字体为黑色.使用下面注释的这行打开亮色状态栏模式,实现黑色字体,白底的需求用这句setStatusBarColor(Color.WHITE);
//            window.getDecorView().setSystemUiVisibility(
//                    View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
window.setStatusBarColor(Color.TRANSPARENT);

}else if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT){//4.4 全透明状态栏
window.addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
}


那么,我们把这个亮色模式打开后如何恢复回来呢?被我试到了下面这个TAG可以实现.

window.getDecorView().setSystemUiVisibility(
View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_VISIBLE);


使用这个就会让状态栏的黑字变回到白字.

下面看下我所实现的效果吧.

android7.0下



android5.0下



android4.4下

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: