这是我的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下面的屏幕顶部,折叠高度相当于工具栏的折叠高度。我尝试将android:layout_gravity="fill_vertical"
添加到RecyclerView,但这并没有解决问题
A Note
当CollapsingToolbarLayout的高度设置为625dp时,屏幕根本不会滚动,但是,当我将其设置为626dp时,屏幕内容会滚动,直到CollapsingToolbarLayout折叠到a的高度工具栏,所以额外的1dp高度使屏幕从不滚动到滚动超过1dp。 625dp的数字可能与设备的屏幕尺寸有关(Nexus 7 2013)。此外,无论我将CollapsingToolbarLayout设置为minHeight
,CollapsingToolbarLayout总是在与工具栏等效的高度折叠。
我的问题简而言之
如何制作,以便屏幕仅滚动显示不在屏幕上/超出RecyclerView内容的内容?
提前致谢。
答案 0 :(得分:0)
我找到了解决方法,您可以为AppBarLayout childView设置“ minHeight”,并设置app:layout_scrollFlags =“ scroll | exitUntilCollapsed”