使用CoordinatorLayout时,我的ScrollView大小不正确

bee*_*tra 44 android android-scrollview android-support-library material-design android-design-library

我用了一个布局的滚动型,并在尝试使用新的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:layout_width="match_parent"
    android:layout_height="match_parent">

  <ScrollView
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      app:layout_behavior="@string/appbar_scrolling_view_behavior">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical">
      ...
    </LinearLayout>
  </ScrollView>
  <android.support.design.widget.AppBarLayout
      android:layout_width="match_parent"
      android:layout_height="wrap_content">
    <android.support.v7.widget.Toolbar ... />
  </android.support.design.widget.AppBarLayout>
</android.support.design.widget.CoordinatorLayout>
Run Code Online (Sandbox Code Playgroud)

测试时,scrollview仅占用屏幕的一部分.什么地方出了错?

bee*_*tra 122

标准ScrollView仅用作父级.您需要将ScrollView更改为android.support.v4.widget.NestedScrollView.

可以在参考文档中看到一个示例AppBarLayout.


liv*_*ove 5

NestedScrollView 就像 ScrollView,但它支持在新旧版本的 Android 上同时充当嵌套滚动父项和子项。默认情况下启用嵌套滚动。

您可以在父 ScrollView 中使用 NestedScrollView。NestedScrollView 在另一个滚动视图中需要滚动视图时使用。这就是它有用的地方,当系统需要决定滚动哪个视图时。

这是一个带有 CoordinatorLayout 的 NestedScrollView 示例:

 <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.support.v4.widget.NestedScrollView
             android:layout_width="match_parent"
             android:layout_height="match_parent"
             app:layout_behavior="@string/appbar_scrolling_view_behavior">

         <!-- Your scrolling content -->

     </android.support.v4.widget.NestedScrollView>

     <android.support.design.widget.AppBarLayout
             android:layout_height="wrap_content"
             android:layout_width="match_parent">

         <android.support.v7.widget.Toolbar
                 ...
                 app:layout_scrollFlags="scroll|enterAlways"/>

         <android.support.design.widget.TabLayout
                 ...
                 app:layout_scrollFlags="scroll|enterAlways"/>

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

 </android.support.design.widget.CoordinatorLayout>
Run Code Online (Sandbox Code Playgroud)