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 App - 无法使用遥控器选择列表项

如何在 android tv 的详细概述中更改操作项的文本颜色/样式

Android tv:标题片段中每个项目的 Webview

Android TV 中缺少应用栏的替代方案

使用 RowsFragment 时,ObjectAdapter.setPresenterSelector 有啥作用吗?

如何在 Android TV 中开始视频录制(开发)