Вложенный RecyclerView не перерабатывается - PullRequest
0 голосов
/ 04 мая 2018

У меня очень сложный пользовательский интерфейс, для которого требуется несколько вложенных списков списков и т. Д.

В настоящее время у меня есть внешний RecyclerView, а внутри есть еще один RecyclerView, который на самом деле является расширяемым утилизатором (это переработанная версия этого компонента ). Это трехслойная иерархия.

Моя проблема в том, что ничто не перерабатывается. У меня их нет внутри NestedScrollView. Они загружаются в память с момента их создания, и onBindViewHolder никогда не запускается снова. В результате прокрутка очень грубая.

Любое предложение о том, как решить эту проблему? Заранее спасибо

Наружный переработчик

<?xml version="1.0" encoding="utf-8"?>
<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:fillViewport="true"
    android:background="@color/color_background_expandable_list">
    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
        <android.support.v7.widget.Toolbar
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimary"
            app:layout_scrollFlags="scroll|enterAlways|snap"
            app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
            app:contentInsetStart="0dp">
            <android.support.v7.widget.RecyclerView
                android:id="@+id/rcv_bet_sports"
                android:scrollbars="none"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:background="#3D464F" />
        </android.support.v7.widget.Toolbar>
    </android.support.design.widget.AppBarLayout>
    <android.support.v7.widget.RecyclerView
        android:id="@+id/rcv_live"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="10dp"
        android:layout_marginBottom="10dp"
        android:layout_marginRight="5dp"
        android:layout_marginLeft="5dp"
        android:descendantFocusability="blocksDescendants"
        app:layout_behavior="@string/appbar_scrolling_view_behavior" />
</android.support.design.widget.CoordinatorLayout>

Внутренний расширяемый ресайклер

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout 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="wrap_content">
    <android.support.v7.widget.RecyclerView
        android:id="@+id/rcv_live"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />
</FrameLayout>

UPDATE Это основной внешний адаптер. Я переопределяю GetItemViewId. Влияет ли это на механизм утилизации?

class LivePageAdapter : RecyclerView.Adapter
    {
        LiveContentPresenter _ContentPresenter;
        RecyclerView.RecycledViewPool _SharedPool = new RecyclerView.RecycledViewPool();

        public LivePageAdapter(LiveContentPresenter contentPresenter)
        {
            _ContentPresenter = contentPresenter;
        }

        public void AddWidget(PageWidgetModel widgetModel)
        {
            _ContentPresenter.Add(widgetModel);
        }

        public override int ItemCount => _ContentPresenter.WidgetCount;

        public override void OnBindViewHolder(RecyclerView.ViewHolder holder, int position)
        {
            _ContentPresenter.BindWidgetOnRow((LiveListViewHolder)holder, position);
        }

        public override RecyclerView.ViewHolder OnCreateViewHolder(ViewGroup parent, int viewType)
        {
            var type = (WidgetType)viewType;
            switch (type)
            {
                case WidgetType.Carousel:
                    return null;
                case WidgetType.HotRightNow:
                    return null;
                case WidgetType.ExpandableRecycler:
                    View liveListItem = LayoutInflater.From(parent.Context).Inflate(Resource.Layout.widget_row_live_list, parent, false);
                    return new LiveListViewHolder(liveListItem, _SharedPool);
                default:
                    return null;
            }
        }

        public override long GetItemId(int position)
        {
            return _ContentPresenter.WidgetModels[position].GetHashCode();
        }

        public override void OnViewRecycled(Java.Lang.Object holder)
        {
            base.OnViewRecycled(holder);
        }

        public override int GetItemViewType(int position)
        {
            return _ContentPresenter.GetWidgetType(position);
        }
    }

1 Ответ

0 голосов
/ 04 мая 2018

Это происходит, когда у детей неправильный рост.

Просто установите layout_height на wrap_content дочернего элемента, чтобы исправить это.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...