关于状态栏StatusBar(System UI)的各种操作...

1、透明状态栏,内容延伸至状态栏

在主题中设置
API 19

<style name="AppTheme.ExtendStatusBar" parent="AppTheme">
    <item name="android:windowTranslucentStatus">true</item>
</style>

API 21

<style name="AppTheme.ExtendStatusBar" parent="AppTheme">
    <item name="android:windowTranslucentStatus">false</item>
    <item name="android:windowTranslucentNavigation">true</item>
    <item name="android:statusBarColor">@android:color/transparent</item>
</style>

注意:
1、windowTranslucentStatus,如果为true,状态栏就会变成半透明的
2、windowTranslucentStatus、windowTranslucentNavigation,都可以触发LAYOUT_FULLSCREEN 、LAYOUT_STABLE
android windowTranslucentNavigation

或者

    <style name="AppTheme.ExtendStatusBar" parent="AppTheme">
        <item name="android:statusBarColor">@android:color/transparent</item>
    </style>

+

    if(Build.VERSION.SDK_INT>=19){
        View decorView=getWindow().getDecorView();
        int option=View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN 
                                    | View.SYSTEM_UI_FLAG_LAYOUT_STABLE;
        decorView.setSystemUiVisibility(option);
    }

注意:
1、LAYOUT_FULLSCREEN:使状态栏出现的时候,不会重新调整activity的高度,状态栏覆盖在activity之上。
2、LAYOUT_STABLE:
3、LAYOUT_FULLSCREEN 、LAYOUT_STABLE:让应用的主体内容占用系统状态栏的空间;
4、statusBarColor:使状态栏透明

布局文件

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/main_content"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <ImageView
        android:id="@+id/backdrop"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scaleType="centerCrop"
        android:src="@drawable/ic_yd_1"/>

</FrameLayout>

也可以在代码中设置:

    if(Build.VERSION.SDK_INT>=21){
        View decorView=getWindow().getDecorView();
        int option=View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
                | View.SYSTEM_UI_FLAG_LAYOUT_STABLE;
        decorView.setSystemUiVisibility(option);
        getWindow().setStatusBarColor(Color.TRANSPARENT);
    }
}
内容延伸至状态栏,透明状态栏

布局文件:

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/main_content"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <ImageView
        android:id="@+id/backdrop"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scaleType="centerCrop"
        android:src="@drawable/ic_yd_1"/>

</FrameLayout>
Make Content Appear Behind the Status Bar

2、半透明的状态栏 Translucent Status Bar

Translucent ,是在Android 4.4加入的,它的实现方法有两种:在主题文件中设置、通过setFlags()方法设置;在Android 4.4、5.X、6.X的实现方法是相同的,但效果略有差别。

在主题中设置:

<style name="AppTheme.ColorStatusBar" parent="AppTheme">
    <item name="android:windowTranslucentStatus">true</item>
    <item name="android:windowTranslucentNavigation">true</item>
</style>

windowTranslucentStatus,当它被设置以后,system UI就会被自动的设置为SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN、SYSTEM_UI_FLAG_LAYOUT_STABLE,让应用的主体内容占用系统状态栏的空间

android:windowTranslucentStatus
FLAG_TRANSLUCENT_STATUS

在代码中设置:

if(Build.VERSION.SDK_INT>=19){
    getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
}

布局文件:

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/main_content"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <ImageView
        android:id="@+id/backdrop"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scaleType="centerCrop"
        android:src="@drawable/ic_yd_1"/>

</FrameLayout>
API 21,半透明的状态栏
API 19,半透明的状态栏

3、沉浸式 Immersive

Immersive,也是在Android 4.4中引入的,它是Full Screen(隐藏状态栏、导航栏)的一种
在Android 4.4以上,提供了两种Full Screen的方法:

  • Lean Back:点击屏幕的任何位置,显示System Bar
  • Immersive:从隐藏system bar的地方滑动,显示System Bar

参考:
android fullscreen#immersive
materialsystem-bars

主题文件

<style name="AppTheme.ExtendStatusBar" parent="AppTheme">
    <item name="android:windowFullscreen">true</item>
</style>

在代码中可以通过调用setSystemUiVisibility()方法实现Immersive(在Android 4.4、5.X、6.X的实现方法是相同的),代码如下:

@Override
public void onWindowFocusChanged(boolean hasFocus) {
    super.onWindowFocusChanged(hasFocus);
    if(hasFocus && Build.VERSION.SDK_INT>=19){
        View decorView=getWindow().getDecorView();
        int option=View.SYSTEM_UI_FLAG_FULLSCREEN
                | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION
                | View.SYSTEM_UI_FLAG_IMMERSIVE
                | View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY ;
        decorView.setSystemUiVisibility(option);
    }
}

1、SYSTEM_UI_FLAG_FULLSCREEN :隐藏状态栏,手指从屏幕顶部向下拖拽,状态栏会再次出现,且不会消失;activity的界面会重新调整大小
2、SYSTEM_UI_FLAG_HIDE_NAVIGATION :隐藏导航栏,activity的界面会重新调整大小
3、 IMMERSIVE:沉浸模式
4、SYSTEM_UI_FLAG_IMMERSIVE 、SYSTEM_UI_FLAG_IMMERSIVE_STICKY:实现Immersive的全屏效果,不是Lean Back的全屏效果,防止仅仅点击屏幕,System UI就出来了,是粘性的沉浸模式,状态栏和导航栏在显示一段时间后,会自动隐藏

第一次,全屏时

全屏,沉浸式,隐藏状态栏

4、彩色状态栏,设置Status Bar的颜色

在Android 5.0中,Status Bar的颜色标签是colorPrimaryDark,ToolBar的颜色标签为colorPrimary。
或者在主题中进行配置:

** API 21 **

<style name="AppTheme.ColorStatusBar" parent="AppTheme">
    <item name="android:statusBarColor">#245677</item>
    <item name="android:navigationBarColor">@color/colorAccent</item>
</style>
API 21,彩色状态栏
StatusBarColor

</br>

** API 19 **

但是,在API 19中没有statusBarColor这个属性,没办法设置其颜色

使用第三方库,systembartint

compile 'com.readystatesoftware.systembartint:systembartint:1.0.3'

代码如下

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT && Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
    setTranslucentStatus(true);
    // create our manager instance after the content view is set
    SystemBarTintManager tintManager = new SystemBarTintManager(this);
    // enable status bar tint
    tintManager.setStatusBarTintEnabled(true);
    // set a custom tint color for all system bars
    tintManager.setStatusBarTintColor(Color.parseColor("#8df95f"));
}


@TargetApi(19)
private void setTranslucentStatus(boolean on) {
    Window win = getWindow();
    WindowManager.LayoutParams winParams = win.getAttributes();
    final int bits = WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS;
    if (on) {
        winParams.flags |= bits;
    } else {
        winParams.flags &= ~bits;
    }
    win.setAttributes(winParams);
}
API 19,彩色状态栏

</br></br>

** 总之 **

1、透明/半透明状态栏、全屏,在API 19以上都可以实现,可能效果上会有差异;彩色状态栏在API 21以上才可以轻松的实现。

2、android:fitsSystemWindows=“true” :当系统UI(状态栏、导航栏)可见的时候,通过在 View 上设置和系统UI一样高度的边框(padding ),来确保内容不会出现到系统窗口下面。

3、View下的几个flag

  • LAYOUT_FULLSCREEN 、LAYOUT_STABLE:让应用的主体内容占用系统状态栏的空间,在使用windowTranslucentStatus、windowTranslucentNavigation时,这两者都会被调用,可以结合statusBarColor(API 21)实现透明状态栏。
  • FULLSCREEN、HIDE_NAVIGATION,可以实现隐藏状态栏和导航栏,在实现全屏效果时经常会用到,为了实现更真实的全屏,通常还要结合IMMERSIVE、IMMERSIVE_STICKY。

</br>

</br>
参考:
http://www.tuicool.com/articles/faA3MbJ
https://www.zhihu.com/question/24908570
http://www.tuicool.com/articles/QJFzMfY
https://developer.android.com/training/system-ui/navigation.html#40
https://developer.android.com/reference/android/R.attr.html#windowDrawsSystemBarBackgrounds
http://www.jianshu.com/p/2ef52f357aa0

https://www.youtube.com/watch?v=cBi8fjv90E4

刨根问底-论Android“沉浸式”

</br></br></br>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容

  • 概述 通常来说,System bars(包含status bar和navigation bar,如下图所示, 1代...
    小芸论阅读 3,949评论 0 9
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,887评论 25 707
  • 实现辅助(外挂)参考地址:http://developer.android.com/training/access...
    AFinalStone阅读 1,420评论 0 0
  • 人生百味,自己体会! 我们出生的那一刻,就知道要品味人生的味道了,所以我们大哭! 人生不如意,需要我们自己品味不如...
    时光_fe09阅读 253评论 0 0
  • 工地上, 那些风吹日晒的人们, 顶着严寒和酷暑, 身边是钢筋 和混凝土。 没有空调, 没有WIFI, 没有干净的衣...
    大飞_YEah阅读 221评论 0 1