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