当将回收站视图放置在nestedscrollview内时,PagedListAdapter会获取所有项目

时间:2019-05-12 19:43:52

标签: android android-recyclerview android-architecture-components android-nestedscrollview android-paging-library

我正在使用NestedScrollView,在其中,我有一些编辑文本和按钮,然后是RecyclerView。当我打开活动时,所有项目都开始使用PageKeyedDataSource从服务器获取,并且RecyclerView滚动得非常慢,最终应用程序显示ANR。

我在android-architecture-components的GitHub存储库中查看了此问题,发现SmartNestedScrollView可以解决此问题,但是当我使用SmartNestedScrollView时,回收器视图滚动只占一小部分。

https://github.com/googlesamples/android-architecture-components/issues/215

LayoutFile.xml

<?xml version="1.0" encoding="utf-8"?>
<com.magtappofficial.app.utilities.SmartNestedScrollView
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fillViewport="true"
    android:layout_margin="16dp"
    tools:context=".ui.Home">

<androidx.constraintlayout.widget.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">

    <LinearLayout
            android:focusable="true"
            android:focusableInTouchMode="true"
            android:layout_width="0px"
            android:layout_height="0px"/>


    <EditText.../>

    <ImageView.../>

    <ProgressBar
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/newsProgress"
            android:layout_marginTop="16dp"
            app:layout_constraintTop_toBottomOf="@+id/exclusiveForYou"
            app:layout_constraintEnd_toEndOf="parent"
            android:layout_marginEnd="8dp"
            android:layout_marginRight="8dp"
            app:layout_constraintStart_toStartOf="parent"
            android:layout_marginLeft="8dp"
            android:layout_marginStart="8dp"/>

    <androidx.recyclerview.widget.RecyclerView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:id="@+id/newsRecycler"
            android:layout_marginTop="16dp"
            app:layout_constraintTop_toBottomOf="@+id/exclusiveForYou"
            app:layout_constraintEnd_toEndOf="parent"
            android:layout_marginEnd="8dp"
            android:layout_marginRight="8dp"
            app:layout_constraintStart_toStartOf="parent"
            android:layout_marginLeft="8dp"
            android:layout_marginStart="8dp"/>

</androidx.constraintlayout.widget.ConstraintLayout>

</com.magtappofficial.app.utilities.SmartNestedScrollView>

有人可以告诉我我还能做什么吗?

1 个答案:

答案 0 :(得分:0)

注意:这不是最佳做法,这只是一种解决方法,如果有人有更好的答案,请分享。

对于那些仍在寻找答案的人,我有一个简单的解决方法。

我刚刚将要显示在“回收者”视图内的“回收者”视图上方的整个视图移动了,即,使该视图成为“回收者视图”的标题。

Layout Blueprint

在回收站视图内:

const val HEADER = 0
const val REAL_ITEM = 1

getItemViewType方法将视图类型返回到onCreateViewHolder。

override fun getItemViewType(position: Int): Int {
        return when (position) {
            0 -> HEADER
            else -> REAL_ITEM
        }
    }

在onCreateViewHolder方法内部:

override fun onCreateViewHolder(p0: ViewGroup, p1: Int): NewsViewHolder {
        val view = when (p1) {
            HEADER -> {
                LayoutInflater.from(ctx).inflate(R.layout.rv_header, p0, false)
            }
            else -> LayoutInflater.from(ctx).inflate(R.layout.xyz, p0, false)
        }
        return SomeViewHolder(view)
    }

在onBindViewHolder中,您可以获取视图类型并根据视图要求绑定数据。

override fun onBindViewHolder(p0: NewsViewHolder, p1: Int) {
        val viewType = getItemViewType(p1)
}