6

我试图将windowTranslucentStatusAppBarLayoutToolbarapp:layout_scrollFlags="scroll|enterAlways"使用windowTranslucentStatus隐藏工具栏

测试同时在API的18,19和22(左)标记。

Case study

问题是最高的API,在工具栏状态栏下partialy可见。我尝试了许多风格的组合,但这是我得到的最接近的。

在风格我用:

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar"> 
    <item name="android:colorPrimary" tools:targetApi="lollipop">@color/primary</item> 
    <item name="android:colorPrimaryDark" tools:targetApi="lollipop">@color/primary_dark</item> 
    <item name="colorPrimary">@color/primary</item> 
    <item name="colorPrimaryDark">@color/primary_dark</item> 
    <item name="colorAccent">@color/primary</item> 
    <item name="android:colorAccent" tools:targetApi="lollipop">@color/primary</item> 
    <item name="android:windowTranslucentStatus" tools:targetApi="kitkat">true</item> 
    <item name="android:windowBackground">@color/background</item> 
    <item name="android:windowActionBarOverlay">true</item> 
    <item name="android:windowContentOverlay">@null</item> 
</style> 

这里是我的布局XML:

<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:app="http://schemas.android.com/apk/res-auto" 
android:id="@+id/coordinator_layout" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:background="?attr/colorPrimary" 
android:fitsSystemWindows="true"> 

<android.support.design.widget.AppBarLayout 
    android:id="@+id/appbar" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    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:minHeight="?attr/actionBarSize" 
     app:layout_scrollFlags="scroll|enterAlways" 
     app:popupTheme="@style/ThemeOverlay.AppCompat.Light" /> 

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

<android.support.v7.widget.RecyclerView 
    android:id="@+id/recycler_view" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:background="@color/background" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 


<android.support.design.widget.FloatingActionButton 
    android:id="@+id/add_button" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    app:backgroundTint="@color/green" 
    app:layout_anchor="@id/recycler_view" 
    app:layout_anchorGravity="bottom|right|end" /> 

我创建样例应用程序,它可在github

这个难题有什么缺失吗?

回答

4

修正了它。它可能不是最美丽的解决方案,但它是在19和22号测试的。我向协调器布局添加了负边距,并在工具栏上添加了一个正边距(因为这是状态栏的高度,因此为25dp)。

<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    android:id="@+id/coordinator_layout" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:background="?attr/colorPrimary" 
    android:fitsSystemWindows="true" 
    android:layout_marginTop="-25dp"> 

    <android.support.design.widget.AppBarLayout 
     android:id="@+id/appbar" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     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:minHeight="?attr/actionBarSize" 
      app:layout_scrollFlags="scroll|enterAlways" 
      app:popupTheme="@style/ThemeOverlay.AppCompat.Light" 
      android:layout_marginTop="25dp"/> 

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

    <android.support.v7.widget.RecyclerView 
     android:id="@+id/recycler_view" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:background="@color/background" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 


    <android.support.design.widget.FloatingActionButton 
     android:id="@+id/add_button" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     app:backgroundTint="@color/green" 
     app:layout_anchor="@id/recycler_view" 
     app:layout_anchorGravity="bottom|right|end" /> 

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

enter image description here

+0

这实际上可能会工作...将稍后检查 –

+0

良好的破解,致力于我提到的所有3 APIs! :) –

+0

很高兴我能帮到:) – crysxd

0

你有没有试过把以下内容加入RecyclerView

app:layout_behavior="@string/appbar_scrolling_view_behavior" 

我认为它需要与CoordinatorLayout一起使用。另请检查您的com.android.support:recyclerview-v7版本是否已更新。

+0

我做了,一定是从代码中意外删除了它 –

1

我设置

android:fitsSystemWindows="false" on CoordinatorLayout. 

希望帮助你也定了!

+0

坦克正常工作 – HPbyP