Android状态栏以协调器布局向上滚动,使状态图标与工具栏标题重叠

时间:2015-11-30 00:53:17

标签: android xml android-layout android-coordinatorlayout

使用包含AppBarLayout(持有ToolBar和TabLayout)和ViewPager(保留片段)作为子项的协调器布局时遇到问题。我希望在向下滚动时隐藏顶部栏,并在向上滚动时显示。但是,当我向下滚动时,状态栏也会向上滚动,顶部栏位于状态图标的正下方,与它们重叠。

我尝试添加android:fitsSystemWindows =" true" AppBarLayout和ViewPager都没有改变。

使用的代码和显示两种状态的快照:

<android.support.design.widget.CoordinatorLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true">

    <android.support.design.widget.AppBarLayout
        android:layout_height="wrap_content"
        android:layout_width="match_parent"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimary"
            app:layout_scrollFlags="scroll|enterAlways"
            app:popupTheme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"/>

        <android.support.design.widget.TabLayout
            android:id="@+id/sliding_tabs"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:tabMaxWidth="0dp"
            app:tabGravity="fill"
            app:tabMode="fixed"/>

    </android.support.design.widget.AppBarLayout>

    <android.support.v4.view.ViewPager
        android:id="@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

</android.support.design.widget.CoordinatorLayout>

Status Bar without scroll applied

Status Bar with scroll applied

1 个答案:

答案 0 :(得分:31)

查看活动的主题,如果主题是@ style / AppTheme.NoActionBar或没有ActionBar的一个主题,请尝试添加颜色,你必须有一个样式(v21),如下所示:

<style name="AppTheme.NoActionBar">
    <item name="windowActionBar">false</item>
    <item name="windowNoTitle">true</item>
    <item name="android:windowDrawsSystemBarBackgrounds">true</item>
    <item name="android:statusBarColor">@android:color/transparent</item>    
</style>

将其更改为:

<style name="AppTheme.NoActionBar">
    <item name="windowActionBar">false</item>
    <item name="windowNoTitle">true</item>
    <item name="android:windowDrawsSystemBarBackgrounds">true</item>
    <item name="android:statusBarColor">@color/colorPrimaryDark</item>
</style>