带有 RecyclerView 的 CoordinatorLayout 在屏幕底部留下空白空间

Mic*_*ons 7 java android android-recyclerview android-coordinatorlayout android-collapsingtoolbarlayout

这是我的 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:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/background_colour"
        >

        <android.support.design.widget.AppBarLayout
            app:layout_scrollFlags="scroll|exitUntilCollapsed"
            android:id="@+id/profile_screen_appBar"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
            android:fitsSystemWindows="true"
            android:minHeight="150dp"
            >

            <android.support.design.widget.CollapsingToolbarLayout
                app:layout_scrollFlags="scroll|exitUntilCollapsed"
                android:fitsSystemWindows="true"
                android:id="@+id/collapsingToolbar"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                app:expandedTitleMarginTop="32dp"
                app:expandedTitleMarginBottom="32dp"
                app:expandedTitleMarginEnd="4dp"
                app:expandedTitleMarginStart="32dp"
                android:minHeight="100dp"
                >

                <android.support.v7.widget.Toolbar
                    android:minHeight="100dp"
                    android:id="@+id/toolbar"
                    android:layout_width="match_parent"
                    android:layout_height="?attr/actionBarSize"
                    app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
                    android:background="@color/fab_material_red_500"
                    >

                </android.support.v7.widget.Toolbar>


             <RelativeLayout
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:background="@color/blue"
                    >

  <!-- the ViewPager is programatically set to be have the height and width equivalent to that of the screen width of the device -->              <com.example.heavymagikhq.MyViewPager
                        android:padding="0dp"
                        android:fitsSystemWindows="true"
                        android:id="@+id/viewPager"
                        android:layout_width="0dp"
                        android:layout_height="0dp"
                        app:layout_scrollFlags="scroll|enterAlways"/>
                    />

                </RelativeLayout>

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

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

       <android.support.v7.widget.RecyclerView
            android:layout_marginTop="15dp"
            android:layout_marginLeft="6dp"
            android:layout_marginRight="6dp"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:id="@+id/profile_info_recycler"
            app:layout_behavior="@string/appbar_scrolling_view_behavior"
            />
    </android.support.design.widget.CoordinatorLayout>
Run Code Online (Sandbox Code Playgroud)

问题

目前 中的一些内容RecyclerView稍微离开屏幕,我可以通过滚动来显示它。问题是,虽然只有少量内容不在屏幕上,但整个屏幕会向上滚动,直到只有 RecyclerView 的内容显示在屏幕顶部 CollapsingToolbarLayout 下方,折叠高度等于 Toolbar 的折叠高度。我试过添加android:layout_gravity="fill_vertical"到 RecyclerView 但这并没有解决问题

一张纸条

当 CollapsingToolbarLayout 的高度设置为 625dp 时,屏幕根本不滚动,但是,当我将其设置为 626dp 时,屏幕内容会滚动,直到 CollapsingToolbarLayout 折叠到工具栏的高度,所以这个额外的 1dp 高度使得屏幕从不滚动到滚动超过 1dp。625dp 的数字大概与设备 (Nexus 7 2013) 的屏幕尺寸有关。此外,无论minHeight我将 CollapsingToolbarLayout 设置为什么,CollapsingToolbarLayout 总是在与工具栏等效的高度处折叠。

我的问题简而言之

我怎样才能让屏幕只滚动以显示不在屏幕上/超出 RecyclerView 内容的内容?

提前致谢。

小智 1

我找到解决方案\xef\xbc\x8cyou可以为AppBarLayout childView设置“minHeight”,并设置app:layout_scrollFlags="scroll|exitUntilCollapsed"

\n