Android TV:在某些情况下,RowsFragment项目点击无效

7

我正在开发一款Android TV应用程序,遇到了与项目单击侦听器相关的奇怪问题:一切正常,但有时点击不会传播,很可能是未设置侦听器。

我已经创建了RowsFragment的子类,并以6个元素的行来显示我的图像:这意味着网格的每一行实际上是适配器中的一行,即使视觉上相片在同一个月中。 请查看下面的图片以更好地理解。

enter image description here

现在的问题是:当我启动应用程序并向下滚动时,图片上不可见的第一行(因此第四行,因为这里呈现了3行)无法响应我的“点击”,什么也不会发生。这对于第5、6、...行也可能是真实的,但是之后(我没有认出模式)行又开始可被点击了(即第8、9、..行) 前三行始终是可点击的。

如果我再次向上滚动,并且那些之前无法点击的行再次出现在屏幕上,现在它们是可点击的。

在片段的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,因此项目单击监听器未设置。这很奇怪,因为监听器设置为主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
@Hless 到目前为止我还没有时间,但我认为我在由Android Studio创建的Android TV示例项目中看到了相同的问题。 我会再次确认一下:如果是这种情况,打开一个问题将会很快且容易。 否则,由于我的项目不是公开的,我需要找时间在github上实现一个示例项目。 - fasteque
我也见过这个问题。将版本回退至com.android.support:leanback-v17:24.2.1解决了我的问题。 - Elvis D'Souza
@ElvisD'Souza 谢谢,很好知道。我会在 Google 问题中提到它。 - fasteque
我有同样的问题。也在Nvidia Shield上。 - Jackky777
1个回答

4

我遇到过相同的问题,但是更新至支持库版本25.4.0修复了此问题。请注意从25.4.0版本开始,您必须包含以下内容:

maven {
    url "https://maven.google.com"
}

在代码库中。请参见支持库设置


是的,我注意到了发行说明中的以下评论:BrowseFragment onItemClicked callbacks broken in 25.3.0。既然你已经测试过了,我就接受你的答案。谢谢。 - fasteque
我也可以确认,这个问题的原因是leanback支持库25.3.x。降级/升级可以解决这个问题。 - dell116
这个问题在支持库28.0.0中仍然存在。 - Sumit T

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接