【问题标题】:Block Toolbar from collapsing when RecyclerView is empty当 RecyclerView 为空时阻止工具栏折叠
【发布时间】:2016-02-01 02:51:02
【问题描述】:

我有 CollapsingToolbarLayout,它依赖于 ViewPager 中 Fragment 中 RecyclerView 的滚动。问题是 ViewPager 太高并且超出了 CoordinatorLayout 的范围,与它是否具有“match_parent”或“wrap_content”layout_height 无关。因此,即使 RecyclerView 只有很少的项目,ViewPager 也会滚动。 另一个问题是我无法在 ViewPager 的片段中制作静态元素。我想让 FAB 漂浮在 RecyclerView 上,但 FAB 位于屏幕的底部边界下方,直到我将其向上滚动。

这里有一些代码

主布局:

<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:background="@android:color/white">

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

<android.support.design.widget.AppBarLayout
    android:id="@+id/appBarLayout"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:fitsSystemWindows="true">

    <android.support.design.widget.CollapsingToolbarLayout
        android:layout_width="match_parent"
        android:layout_height="122dp"
        android:fitsSystemWindows="true"
        android:id="@+id/collapsingToolbar"
        app:expandedTitleMarginStart="56dp"
        app:layout_scrollFlags="scroll|enterAlways">

        <android.support.v7.widget.Toolbar
            android:layout_height="?attr/actionBarSize"
            android:layout_width="match_parent"
            android:id="@+id/toolbar"
            app:layout_collapseMode="pin"/>

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

    <android.support.design.widget.TabLayout
        android:layout_height="?attr/actionBarSize"
        android:layout_width="match_parent"
        android:layout_gravity="bottom"
        android:id="@+id/tabLayout"
        android:background="@color/default_green"
        app:tabIndicatorColor="@color/white"/>

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

片段:

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

<android.support.v7.widget.RecyclerView
    android:layout_height="match_parent"
    android:layout_width="match_parent"
    android:id="@+id/recyclerView"/>


<android.support.design.widget.FloatingActionButton
    android:id="@+id/bookMark"
    android:fitsSystemWindows="true"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:src="@drawable/ic_shape3x"
    android:layout_gravity="end|bottom"
    app:fabSize="normal"
    app:backgroundTint="@color/default_green"
    android:layout_margin="16dp"
    app:elevation="4sp"
    app:borderWidth="0dp"
    android:contentDescription=""/>
</android.support.design.widget.CoordinatorLayout>

【问题讨论】:

    标签: android android-design-library androiddesignsupport android-collapsingtoolbarlayout


    【解决方案1】:

    我设法以这种方式解决了这个问题。首先,我阻止了 AppBarLayout 滚动,就像 here 解释的那样。 然后我将 FAB 直接放置到 CoordinatorLayout 并将它隐藏到 ViewPager 滚动条上,例如here。 我还想要一个 EditText 漂浮在 ViewPager 内的片段之一上。我把它放在 CoordinatorLayout 里面,让它在 ViewPager 滚动时上下滑动。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2016-03-09
      • 1970-01-01
      • 1970-01-01
      • 2023-03-15
      • 1970-01-01
      • 1970-01-01
      • 2015-09-14
      • 2019-10-18
      相关资源
      最近更新 更多