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 работает нормально, но после того, как некоторые из списков GridView прокручивают его, а не прокручиваются больше, даже в gridView больше строк. Прокрутка только для 8-го элемента gridView и 9-го и 10-го элементов не отображается...

Я искал многие ссылки там, люди говорят, что это работает только выше и в версии Lollipop. Ниже приведены некоторые проблемы.

Можно ли запустить Collapse Tollabr ниже версии lollipop?

Thanx для всех....

Ответ 1

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);

Вот пример, демонстрирующий использование GridLayoutManger: http://www.androidhive.info/2016/05/android-working-with-card-view-and-recycler-view/

Ответ 2

Вам необходимо обернуть 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">

Ответ 3

ListView и GridView не работают напрямую с CoordinatorLayout и CollapsibleToolbar.

Попробуйте использовать либо NestedScrollView, либо RecyclerView с GridLayoutManager для создания GridView.

Ответ 4

Я столкнулся с той же проблемой, когда захотел использовать CollapsingToolbarLayout с ListView/GridView.

Они работают только с RecyclerView. Поэтому я рекомендую вам реализовать RecyclerView вместо GridView.

(не рекомендуется). Но если вы все еще хотите продолжить работу с GridView, вот один трюк (jugaad), чтобы решить вашу проблему.

Скроллинг работает нормально, но после того, как некоторые из списков GridView прокручиваются, он застрял и не прокручивается больше, даже в gridView больше. Даже прокрутка только для 8-го элемента gridView и 9-го и 10-го элементов не отображается...

Здесь ваш GridView сдвинут под экраном в соответствии с высотой AppBarLayout, которая 192dp. Таким образом, вы можете добавить те же paddingBottom = 192dp к вашему GridView, чтобы потянуть его и сделать второй последний элемент видимым. Кроме того, не забудьте добавить 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" />

Ответ 5

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 для работы с ним.