Android 实现沉浸式(Translucent Bars)

本文详细介绍如何在Android应用中实现不同版本间的沉浸式UI效果,包括4.4和5.0以上版本的区别处理方法。文章提供了具体代码实例,演示如何通过适配不同API级别来确保UI一致性和美观。

现在好多的app都已经实现了沉浸式,已经是app开发中不可缺少的一部分。关于沉浸式只能在android4.4以上的版本才能实现,而且4.4和5.0以上的版本又有着不同。网上关于沉浸式的文章有很多,但我总感觉处理方法有些不合适(在开发的时候遇到了坑,布局位置计算出现错误),闲话少说直接上代码。
因为版本的不同所以我们要新建两个value资源文件夹value-v19和value-v21, 把value中的style文件复制到两个文件夹下。如在图1所示:
图1

我们再来定义一些颜色用来设置statusbar和toolbar

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="theme_color">#11ADF4</color>
    <color name="statusBarColor">#FF0F8DC6</color>
    <color name="white">#FFFFFF</color>
</resources>

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/activity_main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.feeling.statusbar.MainActivity">

    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/theme_color"
        android:fitsSystemWindows="true">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:text="@string/app_name"
            android:textSize="18sp"
            android:textColor="@color/white"/>
    </android.support.v7.widget.Toolbar>

</RelativeLayout>

这里说一下 android:fitsSystemWindows属性,主要是通过调整当前设置这个属性的view的padding去为我们的status_bar留下空间。

如果在4.4版本中你不写,那么状态栏和Toolbar就会有挤一块的感觉了,类似会这样:
这里写图片描述

MainActivity.class

public class MainActivity extends AppCompatActivity {

    private Toolbar toolbar;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        toolbar= (Toolbar) findViewById(R.id.toolbar);
        toolbar.setTitle("");
        setSupportActionBar(toolbar);
    }
}

先说一下5.0以上的版本如何做,比较简单,我们只要在value-v21下的style文件中添加如下代码即可实现:

<resources>

    <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <item name="windowNoTitle">true</item>
        <item name="windowActionBar">false</item>
        <item name="android:windowDrawsSystemBarBackgrounds">true</item>//5.0以下没有该属性
        <item name="android:statusBarColor">@color/statusBarColor</item>
    </style>//设置statusbar的颜色,5.0以下没有此属性

</resources>

在4.4版本上就少有些复杂,定义style样式,在value-v19中的style.xml中添加

<resources>
    <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <item name="windowNoTitle">true</item>
        <item name="windowActionBar">false</item>
        <item name="android:windowTranslucentStatus">true</item>
    </style>
</resources>

最终效果如下
4.4版本:
4.4效果图

5.0以上的效果图:
这里写图片描述

可以看到4.4中没有渐变色,为了达到与5.0以上版本相同的效果,我们可以这么做,画一个带有渐变色的背景图,在drawable文件下新建一个toolbar_bg.xml。

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

    <item>
        <shape android:shape="rectangle">
            <solid android:color="@color/statusBarColor"/>
        </shape>
    </item>
    <item android:top="@dimen/status_bar_size">
        <shape android:shape="rectangle">
            <solid android:color="@color/theme_color"/>
        </shape>
    </item>
</layer-list>

然后把activity_main.xml文件中的toolbar的背景色改成android:background="@drawable/toolbar_bg"即可。效果图如下:
这里写图片描述
效果终于实现了,但是5.0的出现了问题:
这里写图片描述
没办法得再做一次适配新建layout-v19和layout-v21(如图1所示)创建toolbar_layout.xml (v19)

<?xml version="1.0" encoding="utf-8"?>
<merge xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@drawable/toolbar_bg"
        android:fitsSystemWindows="true">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:text="@string/app_name"
            android:textSize="18sp"
            android:textColor="@color/white"/>
    </android.support.v7.widget.Toolbar>
</merge>

v-21中的只需要把ToolBar中的背景设置成android:background="@color/theme_color"
然后更改activity_main.xml文件代码

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/activity_main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.feeling.statusbar.MainActivity">

    <include layout="@layout/toolbar_layout" />

</RelativeLayout>

运行效果完美适配。(图就不贴出来了)
也可以通过适配dimen.xml,在style-v19和style-v21中新建dimen.xml
v-19:

<resources>
    <dimen name="status_bar_size">26dp</dimen>
</resources>

v-21

<resources>
    <dimen name="status_bar_size">0dp</dimen>
</resources>

效果一样,两种处理方法原理一样。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值