这是我的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>
问题
目前
RecyclerView
中的某些内容略微不在屏幕上,我可以通过滚动显示它。问题在于,尽管屏幕上只有少量内容,但整个屏幕仍会向上滚动,直到RecyclerView的内容显示在CollapsingToolbarLayout下面的屏幕顶部,并且折叠高度等于Toolbar的折叠高度。我尝试将
android:layout_gravity="fill_vertical"
添加到RecyclerView中,但这不能解决问题
注释
当CollapsingToolbarLayout的高度设置为625dp时,屏幕根本不会滚动,但是,当我将其设置为626dp时,屏幕内容会滚动,直到CollapsingToolbarLayout折叠到工具栏的高度为止,所以这额外的1dp高度使屏幕从不滚动转到滚动超过1dp。 625dp的数字大概与设备(Nexus 7 2013)的屏幕尺寸有关。此外,无论我将CollapsingToolbarLayout设置为哪种
minHeight
,CollapsingToolbarLayout始终会以与工具栏相同的高度折叠。
我的问题简而言之
如何使屏幕滚动以显示屏幕上未显示的内容/超出RecyclerView的内容?
提前致谢。
解决方案如下:
我找到了解决方法,您可以为AppBarLayout childView设置“minHeight”,然后设置app:layout_scrollFlags =“scroll | exitUntilCollapsed”