Android 4.4 以上实现透明导航栏和状态栏 Translucent system bar

Android 4.4之前,即使我们打开手机app,我们还总是能看到系统顶部那条黑乎乎的通知栏,这样会使得app稍显突兀。于是Android 4.4开始,便引入了Translucent System Bar的系特性,用于弥补系统通知栏突兀之处。我们先来看看 Translucent System Bar 新特性引入后,发生了什么样的变化。下面截取了中华万年历的天气预报界面QQ音乐主界面 的效果(两个界面的效果实现 Translucent System Bar 的方式有些区别,下文会细讲)

Android 4.4 以上实现透明导航栏和状态栏 Translucent system bar_第1张图片
中华万年历
Android 4.4 以上实现透明导航栏和状态栏 Translucent system bar_第2张图片
QQ音乐


可以看到,系统的通知栏和app界面融为一体。要在Activity中使用 Translucent System Bar 特性,首先需要到AndroidManifest中为指定的Activity设置Theme。但是需要注意的是,我们不能直接在values/style.xml直接去自定义 Translucet System Bar 的Theme,因为改特性仅兼容 Android 4.4 开始的平台,所以直接在values/style.xml声明引入,工程会报错。有些开发者朋友会在代码中去判断SDK的版本,然后再用代码设置Theme。虽然同样可以实现效果,但个人并不推崇这种做法。我所采取的方法则是建立多个SDK版本的values文件夹,系统会根据SDK的版本选择合适的Theme进行设置。大家可以看到上面我的工程里面有valuesvalues-v19values-v21

第一种方式

第一种方式,需要做下面三步设置

1、在valuesvalues-v19values-v21的style.xml都设置一个 Translucent System Bar 风格的Theme

values/style.xml


values-v19/style.xml


values-v21/style.xml


上面需要注意的地方是,无论你在哪个SDK版本的values目录下,设置了主题,都应该在最基本的values下设置一个同名的主题。这样才能确保你的app能够正常运行在 Android 4.4 以下的设备。否则,肯定会报找不到Theme的错误。

2、在AndroidManifest.xml中对指定Activity的theme进行设置


3、在Activity的布局文件中设置背景图片,同时,需要把android:fitsSystemWindows设置为true


activity_image_translucent_bar.xml






到此,第一种实现方式完成,大家可以看看下面的效果

Android 4.4 以上实现透明导航栏和状态栏 Translucent system bar_第3张图片
ImageTranslucentTheme效果

就跟中华万年历的天气预报效果界面一样,系统的整个导航栏都融入了app的界面中,背景图片填满了整个屏幕,看起来舒服很多。这里还有一个android:fitsSystemWindows设置需要注意的地方,后面会在细讲。接下来看第二种实现。

方式二

相比中华万年历,QQ音乐采用的是另外一种实现的方式,它将app的Tab栏和系统导航栏分开来设置。

Android 4.4 以上实现透明导航栏和状态栏 Translucent system bar_第4张图片
QQ音乐效果风格

由于它的Tab栏是纯色的,所以只要把系统通知栏的颜色设置和Tab栏的颜色一致即可,实现上相比方法一要简单很多。同样要到不同SDK版本的values下,创建一个同名的theme,在values-v21下,需要设置系统导航栏的颜色:

values-v21/style.xml


再到ColorTranslucentBarActivity的布局文件activity_color_translucent_bar.xml中设置Tab栏的颜色




    

        

    


到此,我们就可以得到和QQ音乐主界面一样的效果了。

Android 4.4 以上实现透明导航栏和状态栏 Translucent system bar_第5张图片
QQ音乐界面实现效果

到此,就大体介绍完了 Translucent System Bar 的两种实现方式了。

android:fitsSystemWindows的“踩坑”

通过前面的两种方式,大家估计会留意到一个地方,就是所有实现 Translucent System Bar 效果的Activity,都需要在根布局里设置 android:fitsSystemWindows="true" 。设置了该属性的作用在于,不会让系统导航栏和我们app的UI重叠,导致交互问题。这样说可能比较抽象,看看下面两个效果图的对比就知道了。

Android 4.4 以上实现透明导航栏和状态栏 Translucent system bar_第6张图片
有fitsSystemWindows设置
Android 4.4 以上实现透明导航栏和状态栏 Translucent system bar_第7张图片
没有fitsSystemWindows设置

还有需要注意用到Translucent system bar时,activity的顶层布局必须是基本的布局,比如,如果直接用material design里面的CoordinatorLayout做顶层布局时,会出现一些异常问题。



你可能感兴趣的:(android系列)