NestedScrollView中的RecyclerView ScrollListener

时间:2016-10-06 11:28:29

标签: android android-recyclerview infinite-scroll onscrolllistener android-nestedscrollview

我在EndlessRecyclerView的末尾有一个NestedScrollViewEndlessRecyclerView表示:当用户滚动到recyclerView的底部时,它会加载更多数据。这已经实现并在其他地方工作但是当我将recyclerView放在NestedScrollView内时,OnScrollListener事件不会触发。

XML设计:

<NestedScrollView>

     <Other views/>

     <EndlessRecyclerView/>

</NestedScrollView >

代码:

recyclerView.setOnScrollListener(new RecyclerView.OnScrollListener() {
        @Override
        public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
            super.onScrolled(recyclerView, dx, dy);
            // This is never fired! Here is where I implement the logic of EndlessRecyclerView
        }
    });

如何针对上述情况获取滚动事件?

我知道在彼此内部有两个可滚动视图并不好。但是,如果没有两个可滚动的视图,我怎么能得到上述情况?

我已经关注此链接但不起作用:scroll event for recyclerview inside scrollview android

4 个答案:

答案 0 :(得分:42)

要在NestedScrollView下为循环器视图实现无限滚动,可以使用“NestedScrollView.OnScrollChangeListener”

nestedScrollView.setOnScrollChangeListener((NestedScrollView.OnScrollChangeListener) (v, scrollX, scrollY, oldScrollX, oldScrollY) -> {
            if(v.getChildAt(v.getChildCount() - 1) != null) {
                if ((scrollY >= (v.getChildAt(v.getChildCount() - 1).getMeasuredHeight() - v.getMeasuredHeight())) &&
                        scrollY > oldScrollY) {
                        //code to fetch more data for endless scrolling
                }
            }
        });

此处v.getChildCount() -1应该为您提供实施无限滚动的回收站视图。

此外scrollY > oldScrollY确认页面正在向下滚动。

参考:NestedScrollView.OnScrollChangeListener

答案 1 :(得分:1)

nestedScrollView.setOnScrollChangeListener(new NestedScrollView.OnScrollChangeListener()
        {
            @Override
            public void onScrollChange(NestedScrollView v, int scrollX, int scrollY, int oldScrollX, int oldScrollY)
            {
                if (v.getChildAt(v.getChildCount() - 1) != null)
                {
                    if (scrollY > oldScrollY)
                    {
                        if (scrollY >= (v.getChildAt(v.getChildCount() - 1).getMeasuredHeight() - v.getMeasuredHeight()))
                        {
                            //code to fetch more data for endless scrolling
                        }
                    }
                }
            }
        });

答案 2 :(得分:0)

我有一个类似的问题,尽管有些不同。就我而言,当NestedScrollView位于content_main xml(活动的一部分)中时,我在一个片段中有一个recycleview。

我用SwipeRefreshLayout包装了片段中的回收视图

这是我片段的代码:

    <?xml version="1.0" encoding="utf-8"?>
<androidx.swiperefreshlayout.widget.SwipeRefreshLayout
    android:id="@+id/swipe_dummy"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/top_series_recycle_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</androidx.swiperefreshlayout.widget.SwipeRefreshLayout>

剩下要做的就是从代码中禁用SwipeRefreshLayout

mSwipeLayout.isEnabled = false

如果您不这样做,则向下滑动时将显示无休止的刷新图标。 我想分享此解决方案,以防有人需要此功能或遇到此问题

用SwipeRefreshLayout包装完recycleview之后,您将看到 回收站视图的addOnScrollListener将照常被调用

答案 3 :(得分:0)

nestedScrollView.setOnScrollChangeListener { v: NestedScrollView?, scrollX: Int, scrollY: Int, oldScrollX: Int, oldScrollY: Int ->

        val view = nestedScrollView.getChildAt(nestedScrollView.childCount - 1)
        Timber.d("Count==============${nestedScrollView.childCount}")

        val diff = view.bottom - (nestedScrollView.height + nestedScrollView.scrollY)
        Timber.d("diff==============$diff")

        if (diff == 0) {
            //your api call to fetch data
            page++
            apiCall()
        }


    }