Android TV:RowsFragment 项目点击在少数情况下不起作用
Posted
技术标签:
【中文标题】Android TV:RowsFragment 项目点击在少数情况下不起作用【英文标题】:Android TV: RowsFragment item click not working in few cases 【发布时间】:2017-10-18 09:20:54 【问题描述】:我正在开发一个 android TV 应用程序,我遇到了一个与项目点击监听器相关的奇怪问题:一切正常,但有时点击没有传播,很可能没有设置监听器。
我已对RowsFragment
进行了子类化,并且我正在用 6 个元素的行显示我的图像:这意味着网格的每一行实际上是适配器中的一行,即使在视觉上这些照片具有相同的月份。
请查看图片以更好地理解。
现在的问题:当我启动应用程序并向下滚动时,上图中不可见的第一行(所以第四行,因为这里渲染了 3 行),没有得到我的“点击” , 什么都没发生。对于第 5、第 6、... 行,这也可能是正确的,但随后(我没有识别出模式)行开始再次可点击(即第 8、第 9、...) 前 3 行也始终可以点击。
如果我再次向上滚动并且那些不可点击的行再次出现在屏幕上,现在它们是可点击的。
在片段的onCreate
中,我调用:
setOnItemViewClickedListener(new ItemViewClickedListener());
并且根据文档,这应该覆盖由单个项目视图设置的侦听器。还建议设置一个侦听器,而不是两者都设置:实际上我只是为片段设置了一个。
在单行项的Presenter
类中,我尝试在视图的onCreateViewHolder
中添加一个点击监听器,我发现问题发生的时候,这个监听器被调用了。
所以似乎在某些情况下,整体片段侦听器不会覆盖视图侦听器或根本没有设置。
我对此问题还担心的是,当我设置断点并停止滚动动画时,我无法在调试模式下重现它。
我正在使用最新的 Leanback 版本:
compile 'com.android.support:leanback-v17:25.3.1'
在 Nvidia Shield TV (Android 7.0) 上可以重现该问题,但在其他设备上不确定。
更新:同样有趣的是,当一个项目在一行中不可点击时,我希望同一行中的所有项目都不可点击。相反,情况并非如此,有些是可点击的,有些则不是。
更新2:好像ListRowPresenterItemBridgeAdapter
方法onBind
,在某些场合发现getOnItemViewClickedListener
返回null,所以没有设置item点击监听。这很奇怪,因为侦听器是为 RowsFragment
主类设置的,并且它对大多数项目都工作正常,同样行中的项目也不能正常工作。
作为一种解决方法,我找到了这个解决方案:将ListRowPresenter
子类化并为其设置一个虚拟点击侦听器。
private class GroupedListRowPresenter extends ListRowPresenter
GroupedListRowPresenter(int focusZoomFactor)
super(focusZoomFactor);
@Override
protected void onBindRowViewHolder(RowPresenter.ViewHolder holder, Object item)
super.onBindRowViewHolder(holder, item);
holder.setOnItemViewClickedListener(new BaseOnItemViewClickedListener()
@Override
public void onItemClicked(Presenter.ViewHolder itemViewHolder, Object item, RowPresenter.ViewHolder
rowViewHolder, Object row)
Timber.d("item click from dummy listener: this should never happen!");
);
我对此并不满意,因为我真的不喜欢设置一个空的点击监听器,即使我知道它会被覆盖。
更新 3: 这个问题也可以通过 Android Studio 创建的示例应用程序重现,因此它似乎与我的代码中的错误无关。为此我提交了一个错误:https://issuetracker.google.com/issues/62443122
如果您也受到此问题的影响,请在上面的问题上加注星标,以便得到更多关注,谢谢。
【问题讨论】:
感谢您在此处发布进度。有完全相同的问题,您的第二次更新也为我修复了它。不过感觉真的不对,我希望它不会在以后的版本中中断。可能需要为此编写一个 UI 测试 >.<.> @Hless 到目前为止我没有时间,但我想我在 Android Studio 创建的 Android TV 示例项目中看到了同样的问题。我会仔细检查一下:如果是这样的话,打开一个问题会很快很容易。否则,由于我的项目没有开放,我需要找时间在github上实现一个示例项目。 我也见过这个。回滚到com.android.support:leanback-v17:24.2.1
为我解决了这个问题
@ElvisD'Souza 谢谢,很高兴知道。我会在 Google 问题中提到它。
我也有同样的问题。也在 Nvidia Shield 上
【参考方案1】:
我遇到了同样的问题,但更新到支持库版本25.4.0
解决了这个问题。请注意,从 25.4.0 开始,您必须包含
maven
url "https://maven.google.com"
在存储库中。见Support Library Setup。
【讨论】:
是的,我注意到发行说明中有以下评论:BrowseFragment onItemClicked callbacks broken in 25.3.0
。既然你已经测试过了,我会接受你的回答。谢谢。
我也可以肯定这个问题的原因是leanback支持库25.3.x。降级/升级解决了这个问题。
支持库中仍然存在此问题:28.0.0以上是关于Android TV:RowsFragment 项目点击在少数情况下不起作用的主要内容,如果未能解决你的问题,请参考以下文章
如何在 android tv 的详细概述中更改操作项的文本颜色/样式