问题 CollapsingToolbarLayout与GridView的问题


CollapsingToolbarLayout 只与...合作 RecyclerView 但没有合作 ListView 和 GridView

下面是我的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:fitsSystemWindows="true">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appbar"
        android:layout_width="match_parent"
        android:layout_height="192dp"
        android:fitsSystemWindows="true"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/collapsing_toolbar"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:fitsSystemWindows="true"
            app:contentScrim="?attr/colorPrimary"
            app:expandedTitleMarginBottom="32dp"
            app:expandedTitleMarginEnd="64dp"
            app:expandedTitleMarginStart="48dp"
            app:layout_scrollFlags="scroll|exitUntilCollapsed">

            <ImageView
                android:id="@+id/restaurant_image"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:src="@drawable/gradiant"
                app:layout_collapseMode="parallax" />

            <android.support.v7.widget.Toolbar
                android:id="@+id/anim_toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                app:layout_collapseMode="pin"
                app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />
        </android.support.design.widget.CollapsingToolbarLayout>
    </android.support.design.widget.AppBarLayout>

    <android.support.v4.widget.NestedScrollView 
       android:layout_width="match_parent"
       android:layout_height="match_parent"
       android:animateLayoutChanges="true"
       app:layout_behavior="@string/appbar_scrolling_view_behavior"
       android:fillViewport="true">


    <GridView
        android:id="@+id/restaurant_items"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_marginLeft="20dp"
        android:layout_marginRight="20dp"
        android:layout_marginTop="5dp"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"
        android:gravity="center"
        android:numColumns="2"
        android:verticalSpacing="20dp" />

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

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

而这一个是我的 Activity 文件:

        Toolbar toolbar = (Toolbar) findViewById(R.id.anim_toolbar);
        setSupportActionBar(toolbar);
        getSupportActionBar().setDisplayHomeAsUpEnabled(true);
        CollapsingToolbarLayout collapsingToolbar = (CollapsingToolbarLayout) findViewById(R.id.collapsing_toolbar);
        collapsingToolbar.setTitle("Resturant Name");
        ImageView header = (ImageView) findViewById(R.id.restaurant_image);

        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
            ViewCompat.setNestedScrollingEnabled(mGrid,true);
        }

        mGrid.setAdapter(new ResturantItemsAdapter(this, images, name));//images and name is array with size 10....

注意:-Scrolling工作正常但是在一些网格视图列表滚动之后它会卡住而不是滚动更多,即使网格视图中有更多行。它仅滚动网格视图的第8项,第9项和第10项未显示... 

我搜索了许多链接,有人说它只能在上面和Lollipop版本中工作。下面的版本有一些问题。

是否可以在棒棒糖版本下运行折叠工具栏?

谢谢大家 ....


2272
2017-09-09 12:34


起源

您可以使用 RecyclerView 同 GridLayoutManager 代替 GridView。 - Abhishek V
去掉 android:fillViewport="true" 从NestedScrollView中将动态高度设置为ListView或GridView - Hamed Nabizadeh
@HamedNabizadeh你解决方案消失了我折叠工具栏后面的所有项目并且滚动不起作用... - sushildlh
@AbhishekV请你回答我的回答。请在你的答案中加上一些代码示例..... :)。我找到了这个有用的解决方案bcoz androidhive.info/2016/05/... - sushildlh
@sushildlh完成。添加它作为答案。 - Abhishek V


答案:


CoordinatorLayout 用得更好 RecyclerView 要么 NestedScrollView。根据您的要求,您可以使用 RecyclerView 同 GridLayoutManger

<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.support.design.widget.AppBarLayout
        android:id="@+id/appbar"
        android:layout_width="match_parent"
        android:layout_height="192dp"
        android:fitsSystemWindows="true"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/collapsing_toolbar"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:fitsSystemWindows="true"
            app:contentScrim="?attr/colorPrimary"
            app:expandedTitleMarginBottom="32dp"
            app:expandedTitleMarginEnd="64dp"
            app:expandedTitleMarginStart="48dp"
            app:layout_scrollFlags="scroll|exitUntilCollapsed">

            <ImageView
                android:id="@+id/restaurant_image"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:src="@drawable/gradiant"
                app:layout_collapseMode="parallax" />

            <android.support.v7.widget.Toolbar
                android:id="@+id/anim_toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                app:layout_collapseMode="pin"
                app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />
        </android.support.design.widget.CollapsingToolbarLayout>
    </android.support.design.widget.AppBarLayout>

  <android.support.v7.widget.RecyclerView
    android:id="@+id/my_recycler_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    android:scrollbars="vertical" />

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

RecyclerView.LayoutManager mLayoutManager = new GridLayoutManager(this, 2); recyclerView.setLayoutManager(mLayoutManager);

这是一个演示使用的示例 GridLayoutMangerhttp://www.androidhive.info/2016/05/android-working-with-card-view-and-recycler-view/


5
2017-09-22 14:11



thanx的提示,帮助我解决这个问题 - sushildlh
我的荣幸 ;-) - Abhishek V


您需要将GridView和ListView包装在NestedScrollView中并添加正确的行为,如下所示:

<android.support.v4.widget.NestedScrollView 
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:animateLayoutChanges="true"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    android:fillViewport="true">

5
2017-09-09 12:39





ListView和GridView不能直接与CoordinatorLayout和CollapsibleToolbar一起使用。

尝试使用NestedScrollView或带有GridLayoutManager的RecyclerView来创建GridView。


1
2017-09-21 07:34





CoordinateLayout 工作中 ListView 和 GridView 只有你的 API > 21

对于 ListView 你可以像这样编码。

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
     listView.setNestedScrollingEnabled(true);
}

所以在更新 CoordinateLayout 只能使用 NestedScrollView 和 RecycleView

这样 @amitairos 说你必须把 ListView 要么 GridView 至 NestScrollView 使用它。


0
2017-09-22 09:08





当我想将CollapsingToolbarLayout与ListView / GridView一起使用时,我遇到了同样的问题。

它们只适用于RecyclerView。因此,我建议您实现RecyclerView而不是GridView。

(不建议)  - 但是如果你仍然想继续使用GridView,这里有一个技巧(jugaad)来解决你的问题。

滚动工作正常,但是在一些GridView列表滚动后它停滞不动滚动,即使gridView中有更多行。它仅滚动第8项gridView,第9项和第10项未显示...

在这里,你的GridView按照AppBarLayout的高度移动到屏幕下方 192dp 。所以可以添加相同的 paddingBottom = 192dp 到你的 网格视图 将其拉出并使另一个最后2项可见。另外别忘了添加 clipToPadding = false

<GridView
        android:id="@+id/restaurant_items"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_marginLeft="20dp"
        android:layout_marginRight="20dp"
        android:layout_marginTop="5dp"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"
        android:gravity="center"
        android:numColumns="2"
        android:verticalSpacing="20dp"
        android:paddingBottom = "192dp"
        android:clipToPadding = "false" />

0
2017-09-21 09:56



用这个我的最后一个 4项 不见了 ...... - sushildlh
对不起,我的错误.. clipToPadding应该是假的。答案已更新。 - iMDroid