我有一个 RecyclerView 使用 LinearLayoutManager 以 HORIZONTAL 方向嵌套在 FrameLayout 中使用 BottomSheet 行为。
当尝试在 RecyclerView 上垂直拖动时,BottomSheet 不响应拖动事件。据推测,这是因为水平方向的 LayoutManager 禁用了垂直滚动。
我已经尝试覆盖 LinearLayoutManager.canScrollVertically() 并返回 true。这种有点有效。如果您以非常小心的方式垂直拖动,BottomSheet 将响应。但是,一旦涉及任何水平移动,BottomSheet 就会停止响应垂直拖动事件。
我不确定在这里覆盖 canScrollVertically() 是否是正确的方法 - 从用户体验的角度来看,它肯定感觉不对。
我还注意到,如果我使用 ViewPager 而不是带有水平方向 LayoutManager 的 RecyclerView,则 BottomSheet 根据需要响应垂直滑动事件。
LayoutManager、RecyclerView、BottomSheet Behavior 是否有其他一些方法,或者其他可以帮助传播垂直滚动事件的方法到 BottomSheet 行为?
这里有一个问题的例子:
https://github.com/timusus/bottomsheet-test (问题可以通过提交 #f59a7031 重现)
只需展开第一个 Bottom Sheet 。
最佳答案
问题出在哪里?在 FrameLayout 中。 BottomSheet 放在 CoordinatorLayout 中时效果很好。然后 BottomSheet 可以通过 CoordinatorLayout 将其滚动状态传递给作为 CoordinatorLayout 的直接子级的其他 View 。
为什么 RecyclerView 无法将滚动状态传递给 BottomSheet?它不是 CoordinatorLayout 的直接子级。但是有一种方法可以传递它们:RecyclerView 必须放在实现 NestedScrollingParent 的 View 中和 NestedScrollingChild .答案是:NestedScrollView
因此您的 fragment_sheetX.xml 布局应该如下所示:
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.NestedScrollView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#fff"
android:orientation="vertical"
android:fillViewport="true">
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerView"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</android.support.v4.widget.NestedScrollView>
另请注意 android:fillViewport="true" 否则,您的 RecyclerView 将不会占据整个高度。
但是还是不行。为什么? RecyclerView 必须被告知将垂直滚动传递给父级。如何?答案是 recyclerView.setNestedScrollingEnabled(false);,但更好地描述了 here .
顺便说一句:MultiSheetView 是一项很棒的功能,也是一种非常有趣的移动用户体验设计方法。
关于android - RecyclerView(水平)嵌套在 BottomSheet 中防止垂直滚动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43871163/
我得到了一个包含嵌套链接的表单。编辑时链接字段为空的问题。这是我的表格:Editingkategori{:action=>'update',:id=>@konkurrancer.id})do|f|%>'Trackingurl',:style=>'width:500;'%>'Editkonkurrence'%>|我的konkurrencer模型:has_one:link我的链接模型:classLink我的konkurrancer编辑操作:defedit@konkurrancer=Konkurrancer.find(params[:id])@konkurrancer.link_attrib
这道题是thisquestion的逆题.给定一个散列,每个键都有一个数组,例如{[:a,:b,:c]=>1,[:a,:b,:d]=>2,[:a,:e]=>3,[:f]=>4,}将其转换为嵌套哈希的最佳方法是什么{:a=>{:b=>{:c=>1,:d=>2},:e=>3,},:f=>4,} 最佳答案 这是一个迭代的解决方案,递归的解决方案留给读者作为练习:defconvert(h={})ret={}h.eachdo|k,v|node=retk[0..-2].each{|x|node[x]||={};node=node[x]}node[
下面例子中的Nested和Child有什么区别?是否只是同一事物的不同语法?classParentclassNested...endendclassChild 最佳答案 不,它们是不同的。嵌套:Computer之外的“Processor”类只能作为Computer::Processor访问。嵌套为内部类(namespace)提供上下文。对于ruby解释器Computer和Computer::Processor只是两个独立的类。classComputerclassProcessor#Tocreateanobjectforthisc
我的假设是moduleAmoduleBendend和moduleA::Bend是一样的。我能够从thisblog找到解决方案,thisSOthread和andthisSOthread.为什么以及什么时候应该更喜欢紧凑语法A::B而不是另一个,因为它显然有一个缺点?我有一种直觉,它可能与性能有关,因为在更多命名空间中查找常量需要更多计算。但是我无法通过对普通类进行基准测试来验证这一点。 最佳答案 这两种写作方法经常被混淆。首先要说的是,据我所知,没有可衡量的性能差异。(在下面的书面示例中不断查找)最明显的区别,可能也是最著名的,是你的
我有一个名为posts的模型,它有很多附件。附件模型使用回形针。我制作了一个用于创建附件的独立模型,效果很好,这是此处说明的View(https://github.com/thoughtbot/paperclip):@attachment,:html=>{:multipart=>true}do|form|%>posts中的嵌套表单如下所示:prohibitedthispostfrombeingsaved:@attachment,:html=>{:multipart=>true}do|at_form|%>附件记录已创建,但它是空的。文件未上传。同时,帖子已成功创建...有什么想法吗?
我真的为这个而疯狂。我一直在搜索答案并尝试我找到的所有内容,包括相关问题和stackoverflow上的答案,但仍然无法正常工作。我正在使用嵌套资源,但无法使表单正常工作。我总是遇到错误,例如没有路线匹配[PUT]"/galleries/1/photos"表格在这里:/galleries/1/photos/1/edit路线.rbresources:galleriesdoresources:photosendresources:galleriesresources:photos照片Controller.rbdefnew@gallery=Gallery.find(params[:galle
最近因为项目需要,需要将Android手机系统自带的某个系统软件反编译并更改里面某个资源,并重新打包,签名生成新的自定义的apk,下面我来介绍一下我的实现过程。APK修改,分为以下几步:反编译解包,修改,重打包,修改签名等步骤。安卓apk修改准备工作1.系统配置好JavaJDK环境变量2.需要root权限的手机(针对系统自带apk,其他软件免root)3.Auto-Sign签名工具4.apktool工具安卓apk修改开始反编译本文拿Android系统里面的Settings.apk做demo,具体如何将apk获取出来在此就不过多介绍了,直接进入主题:按键win+R输入cmd,打开命令窗口,并将路
我需要根据字符串路径的长度将字符串路径数组转换为符号、哈希和数组的数组给定以下数组:array=["info","services","about/company","about/history/part1","about/history/part2"]我想生成以下输出,对不同级别进行分组,根据级别的结构混合使用符号和对象。产生以下输出:[:info,:services,about:[:company,history:[:part1,:part2]]]#altsyntax[:info,:services,{:about=>[:company,{:history=>[:part1,:pa
1.upto(9){|x|printx}为什么这行不通?{printx|x}}y呢? 最佳答案 它用于传递给您的block的参数。即在您的示例中,upto将使用1到9中的每个数字调用您的block,当前值可作为x获得。block参数可以有任何名称,就像方法参数一样。例如1.upto(9){|num|putsnum是有效的。就像一个方法的参数一样,一个block也可以有多个参数。例如hash.each_pair{|key,value|puts"#{key}is#{value}"} 关于ru
我有一个ActiveRecord对象,我想在不对模型进行永久验证的情况下阻止它被保存。您过去可以使用errors.add执行类似的操作,但它看起来不再有效了。user=User.lastuser.errors.add:name,"namedoesn'trhymewithorange"user.valid?#=>trueuser.save#=>true或user=User.lastuser.errors.add:base,"myuniqueerror"user.valid?#=>trueuser.save#=>true如何在不修改用户对象模型的情况下防止将用户对象保存在Rails3.2中