-1

我知道这是一个坏主意,但我在另一个 RecyclerView 的项目中使用 RecyclerView 来显示包含列表的项目列表。

我设法让它工作并尽可能地对其进行调整,但是green当具有更多项目的列表开始显示并在屏幕上绘制时,我仍然会遇到这些尖峰。

GPU 分析三星 Galaxy S6

这些尖峰在翻阅物品时会产生明显的延迟,并且在使用比三星 Galaxy S6 更慢和更旧的东西时更加明显。

我做了一些日志记录,看来outerViewHolders 正在被回收,而innerRecyclerView 的适配器只创建了 5 次,所以它一定是绘图时间扼杀了性能。

我已经设法通过设置 RecycledViewPool 中的 ViewHolders 的最大数量来限制新innerRecyclerView 的 ViewHolders 的创建,但这只起到了一点作用。

我知道内部 RecyclerView 没有“底部”,它可以依靠它来计算何时显示新项目,因此它必须立即绘制每个项目,这可能是不应使用此设置的主要原因。(当我写下这个问题时,我才恍然大悟。谢谢世界上的橡皮鸭)。

有没有办法可以进一步调整,或者你能建议如何在另一个 RecyclerView 的项目中使用除 RecyclerView 之外的其他设置来完成这项工作吗?

如果需要,我会提供更多信息。

谢谢

4

2 回答 2

2

最好的解决方案是切换回 aListView并使用ExpandableListView 接口,或者自己实现它RecyclerView

正如您所提到的 - 列出滚动组件从来都不是一个好的解决方案。这是一个示例可扩展列表视图适配器,因此您知道需要什么:

public class MyExpandableListAdapter extends BaseExpandableListAdapter {

    ...

    @Override
    public Object getChild(int listPosition, int childListPosition) { 
        //return an item that would have been in one of the nested recyclers
        //(listPosition = parent, childListPosition = nested item number)
       return getGroup(listPosition).getChildren().get(childListPosition);
    }

    @Override
    public int getChildrenCount(int listPosition) {
        //presuming the parent items contain the children
        return getGroup(listPosition).getChildren().size();
    }

    @Override
    public Object getGroup(int listPosition) {
        //group is the parent items (the tope level recycler view items)
        return mData.get(listPosition);
    }

    @Override
    public int getGroupCount() {
        return mData.size();
    }

    @Override
    public View getGroupView(int listPosition, boolean isExpanded, View convertView, ViewGroup parent) {
        if (convertView == null) {
            convertView = mInflater.inflate(R.layout.list_item, parent, false);
        }
        MyDataType item = getGroup(listPosition);
        //set the fields (or better yet, use viewholder pattern)
        return convertView;
    }

    @Override
    public View getChildView(int listPosition, final int expandedListPosition, boolean isLastChild, View convertView, ViewGroup parent) {
        if (convertView == null) {
            convertView = mInflater.inflate(R.layout.list_item, parent, false);
        }
        MyDataType item = getChild(listPosition, expandedListPosition);
        //set the fields (or better yet, use viewholder pattern)
        return convertView;
    }

}
于 2017-03-10T11:26:33.167 回答
-1

我设法通过创建一个 shared 来获得更好的性能RecycledViewPool,因为它是在评论中链接的项目@Raghunandan 中完成的。

Google I/O Android 应用程序 - 共享 RecycledViewsPool

我还设置了该池的最大视图数量,这确实起到了作用,现在我只需要找到一种方法来重用我的监听器并避免创建新的监听器,但这是一个不同的问题。

谢谢大家的回复。如果我将来发现任何有用的东西,我会发布更多。

于 2017-03-10T15:09:41.563 回答