安卓6.0以上ScrollView嵌套RecyclerView条目无法全部显示

针对Android 6.0以上版本中ScrollView嵌套RecyclerView条目显示不全的问题,介绍了通过条件判断添加额外布局来解决的方法。在高版本系统中,使用ViewStub动态加载包含RelativeLayout的RecyclerView,确保列表完整显示,同时保持低版本系统的性能。

安卓6.0以上ScrollView嵌套RecyclerView条目无法全部显示

安卓6.0以上ScrollView嵌套RecyclerView条目无法全部显示

一般情况下,应当避免ScrollView嵌套RecyclerView, 但有时候就需进行嵌套, 以前嵌套listView会导致条目显示不完整, 如果嵌套RecyclerView在6.0以下系统, 初了滑动不太流畅外其他功能全部正常, recyclerView.setNestedScrollingEnabled(false) 可以解决滑动不流畅.

但是如果是6.0以上系统, 列表不能全部显示, 然后就找了下解决方法, 是在当前recycleView控件上在加一个父布局RelativeLayout 这样就可以解决, 添加其他父布局好像是不可以. 这是一个单独的layout,include_punch_field.xml;

<RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content">

            <android.support.v7.widget.RecyclerView
                android:id="@+id/punch_stub_recycle"
                android:layout_width="match_parent"
                android:layout_height="wrap_content" />
        </RelativeLayout>
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

这样解决虽然干脆利落, 但是又多了一层布局的嵌套, 而且还是RelativeLayout, 如果在6.0以下系统, 显然没有必要, 所以我就做了下版本判断, 如果系统版本>=23就使用带有RelativeLayout为父布局的recycleView, 否则的话就不用它.

使用ViewStub, 不使用的时候是不占用布局嵌套层次的, 所以当使用的时候在加载.

 <FrameLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

          <ViewStub
            android:id="@+id/punch_field_stub"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout="@layout/include_punch_field"//RelativeLayout父布局内容
            />

         <android.support.v7.widget.RecyclerView
                android:id="@+id/punch_field_recycle"
                android:layout_width="match_parent"
                android:layout_height="wrap_content" />

    </FrameLayout>
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

加载ViewStub 返回一个recycleView, 如果是>=6.0系统就加载viewStub, 否则的话, 还是用不带有RelativeLayout父布局容器的recycleView, ViewStub 只能加载一次, 多次调用会报空指针.

public RecyclerView getRecycleView() {
        if (Build.VERSION.SDK_INT >= 23) {
            ViewStub punch_field_stub = (ViewStub) findViewById(R.id.punch_field_stub);
            punch_field_stub.inflate();//加载
            return (RecyclerView) findViewById(R.id.punch_stub_recycle);
        }
        return (RecyclerView) findViewById(R.id.punch_field_recycle);
    }
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
            <link href="https://csdnimg.cn/release/phoenix/mdeditor/markdown_views-60ecaf1f42.css" rel="stylesheet">
                                <div></div>
                    
        <div class="person-messagebox">
            <div class="left-message"><a href="https://blog.youkuaiyun.com/lmy_1992">
                <img src="https://profile.csdnimg.cn/9/E/2/3_lmy_1992" class="avatar_pic" username="lmy_1992">
            </a></div>
            <div class="middle-message">
                                    <div class="title"><span class="tit "><a href="https://blog.youkuaiyun.com/lmy_1992" data-report-click="{&quot;mod&quot;:&quot;popu_379&quot;,&quot;ab&quot;:&quot;new&quot;}" target="_blank">我是男子汉</a></span>
                    <!-- 等级,level -->
                                            <img class="identity-icon" src="https://csdnimg.cn/identity/blog2.png">                                            </div>
                <div class="text"><span>原创文章 10</span><span>获赞 3</span><span>访问量 1万+</span></div>
            </div>
                            <div class="right-message">
                                        <a class="btn btn-sm  bt-button personal-watch" data-report-click="{&quot;mod&quot;:&quot;popu_379&quot;,&quot;ab&quot;:&quot;new&quot;,&quot;extend1&quot;:&quot;个人信息未关注&quot;}">关注</a>
                                                            <a href="https://im.youkuaiyun.com/im/main.html?userName=lmy_1992" target="_blank" class="btn btn-sm bt-button personal-letter">私信
                    </a>
                                </div>
                        </div>
                    
    </div>
</article>
<think>好的,我需要帮助用户在Android Studio中使用ListView的setOnScrollChangeListener来判断是否滚动到顶部。首先,我需要回忆一下ListView的相关方法和滚动事件的监听方式。 用户提到的setOnScrollChangeListener是View类中的一个方法,从API 23(Android 6.0)开始引入。所以,如果ListView运行在较旧版本的设备上,这个方法可能可用,需要注意兼容性问题。过,现在大多数应用都支持较新的API,但还是要提醒用户这一点。 接下来,判断ListView是否滚动到顶部。通常可以通过检查第一个可见条目的位置以及其在顶部的偏移量。如果第一个可见条目的位置是0,并且它的偏移量为0,那么可以认为已经滚动到顶部了。 那具体如何在setOnScrollChangeListener中实现呢?监听器的参数包括滚动的X和Y坐标变化,但在这里可能更关注的是Y轴的变化。过,仅仅通过滚动值可能够准确,因为可能有其他因素影响。更好的方式是结合ListView的getFirstVisiblePosition()方法和getChildAt(0)的top值。 在监听器中,每次滚动时,获取ListView的第一个可见位置。如果第一个可见位置是0,再检查该位置的子View的top值是否大于等于0。如果满足这两个条件,说明已经到达顶部。如果top值小于0,说明第一个条目被部分滚动出顶部,这时候可能还没有完全到达顶部。 然后,我需要考虑代码的具体实现。例如,如何获取ListView的实例,设置监听器,并在回调中编写判断逻辑。同时,要注意空指针的情况,比如当ListView没有子项时,调用getChildAt(0)可能会返回null,这时候需要进行判断。 此外,用户提供的引用内容中提到了RecyclerView嵌套滚动设置和ScrollView的滚动监听,这些可能对理解问题背景有帮助,但当前问题主要针对ListView。需要确认是否有其他相关引用内容,但根据提供的引用,可能没有直接关联的信息,过需要确保代码示例的正确性。 最后,可能需要生成相关问题,比如如何判断滚动到底部,或者如何处理兼容性问题等。但根据用户要求,相关问题应围绕当前主题展开。 总结步骤: 1. 设置setOnScrollChangeListener监听滚动事件。 2. 在监听器中,获取ListView的第一个可见位置。 3. 检查第一个可见位置是否为0,并获取对应的子View。 4. 判断子View的top值是否为0,以确认是否滚动到顶部。 5. 处理可能的异常情况,如子View存在的情况。</think>在Android Studio中通过`ListView.setOnScrollChangeListener`判断滚动到顶部的实现步骤如下: ### 步骤说明 1. **设置滚动监听器** 给ListView添加`setOnScrollChangeListener`,监听四种滚动状态变化: ```java listView.setOnScrollChangeListener(new View.OnScrollChangeListener() { @Override public void onScrollChange(View v, int scrollX, int scrollY, int oldScrollX, int oldScrollY) { // 在此处添加判断逻辑 } }); ``` 2. **判断滚动到顶部的条件** 通过以下两个条件判断是否到达顶部: - 第一个可见条目位置为0 `listView.getFirstVisiblePosition() == 0` - 第一个可见条目的顶部偏移量≥0 `listView.getChildAt(0).getTop() >= 0` 3. **完整判断逻辑** ```java listView.setOnScrollChangeListener((v, scrollX, scrollY, oldScrollX, oldScrollY) -> { if (listView.getFirstVisiblePosition() == 0) { View firstChild = listView.getChildAt(0); if (firstChild != null && firstChild.getTop() >= 0) { Log.d("Scroll", "到达顶部"); } } }); ``` ### 注意事项 - **兼容性**:`setOnScrollChangeListener`需API 23+,低版本可使用`setOnScrollListener`[^1] - **空指针检查**:当列表无数据时`getChildAt(0)`可能返回`null`
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值