条目有限的RecyclerView 与ScrollView滑动冲突解决(仅限条目有限)

如下图,这个是我们产品的首页图,看到的第一反应就是标准的ScrollView+RecyclerView(组长要求,项目里所有的列表均用RecyclerView)模式。做完了,发现4.4以上手机有滑动冲突。

最后在网上查到的方法,其实也挺简单的,复写LinearLayoutManager的canScrollVertically方法,返回false,这样RecyclerView就无法滑动了。高度定死了,相当于一个LineaLayout来用。自然没有滑动冲突。但是也有个问题,因为我们的产品中新闻列表条目为写死的10条,所以不滑动一次性全展示就可以了。但是如果是需要滑动展示甚至上拉加载的怎么办呢?想了想(其实是度娘的),用ListView然后在里面添加headerView将上面所有的布局扔里面就可以了。这样就不需要ScrollView了。你无论怎么滑动,滑动的都是ListView,当然也没有滑动冲突了。至于RecyclerView···简单翻了下并没有addHeader或者setHeader的方法。懒得找了,出去吃饭了。下午提测···还没做完呢。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在你的代码中,你使用了一个ScrollView和一个SwipeRefreshLayout,并且想要在ScrollView不在顶部时禁用SwipeRefreshLayout的刷新动作。然而,你遇到了滑动冲突的问题。有两种方法可以解决这个问题。 方法一是使用NestedScrollView替换ScrollView。NestedScrollViewScrollView的一个扩展类,它可以处理滑动冲突的问题。你可以将你的ScrollView替换为NestedScrollView,并将其设置为可以接受一个直接的子视图。这样,你就可以在NestedScrollView不在顶部时禁用SwipeRefreshLayout的刷新动作。\[2\] 方法二是在代码中添加一些逻辑来处理滑动冲突。你可以在ScrollView的滚动事件监听器中添加一些条件判断,以确定ScrollView是否在顶部。如果ScrollView在顶部,你可以启用SwipeRefreshLayout的刷新动作;如果ScrollView不在顶部,你可以禁用SwipeRefreshLayout的刷新动作。这样,你就可以解决滑动冲突的问题。\[3\] 希望这些方法可以帮助你解决SwipeRefreshLayout和ScrollView之间的滑动冲突问题。 #### 引用[.reference_title] - *1* [Android:Swipe与ScrollView滑动冲突问题](https://blog.csdn.net/qq_39085422/article/details/78368791)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v4^insert_chatgpt"}} ] [.reference_item] - *2* *3* [解决SwipeRefreshLayout与ScrollView滑动冲突](https://blog.csdn.net/sunny2come/article/details/82883158)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v4^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值