Android 当RecyclerView为空时阻止工具栏折叠
我有一个折叠工具栏布局,它依赖于ViewPager中的RecyclerView片段的滚动。问题是ViewPager太高,超出了CoordinatorLayout的范围,不管它是否具有“匹配父项”或“换行内容”布局高度。因此,即使RecyclerView只有很少的项目,ViewPager也会滚动。 另一个问题是,我不能在ViewPager的片段中生成静态元素。我想让晶圆浮动在RecyclerView上,但晶圆位于屏幕的底部边界之下,直到我将其向上滚动为止 这里有一些代码 主要布局:Android 当RecyclerView为空时阻止工具栏折叠,android,android-design-library,androiddesignsupport,android-collapsingtoolbarlayout,Android,Android Design Library,Androiddesignsupport,Android Collapsingtoolbarlayout,我有一个折叠工具栏布局,它依赖于ViewPager中的RecyclerView片段的滚动。问题是ViewPager太高,超出了CoordinatorLayout的范围,不管它是否具有“匹配父项”或“换行内容”布局高度。因此,即使RecyclerView只有很少的项目,ViewPager也会滚动。 另一个问题是,我不能在ViewPager的片段中生成静态元素。我想让晶圆浮动在RecyclerView上,但晶圆位于屏幕的底部边界之下,直到我将其向上滚动为止 这里有一些代码 主要布局: <and
<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>
我设法用这种方法解决了这个问题。首先,我阻止了AppBarLayout像前面解释的那样滚动。 然后我将FAB直接放在坐标布局上,并将其隐藏在ViewPager滚动条上,如图所示。 我还想在其中一个片段上浮动一个EditText,它位于ViewPager内部。我把它放在CoordinatorLayout里面,让它在ViewPager滚动时上下滑动