Java RecyclerView重新计算包裹内容

Java RecyclerView重新计算包裹内容,java,android,android-recyclerview,Java,Android,Android Recyclerview,对于23.2版,我们现在可以使用WRAP\u CONTENT来查看recyclerView高度,这非常好。我正在这样做,但是我想在向适配器添加(或删除)项目后重新计算高度(从而增加或减少高度) 我特别的RecyclerView是从1个项目开始,然后在用户进行选择时添加项目。所以我需要RecyclerView布局来增加高度,直到达到一定程度。理想情况下,当列表增加或减少时,平滑动画会出现这种情况 我们如何才能使它在布局后包装内容 尝试: recyclerview.requestLayout();

对于23.2版,我们现在可以使用
WRAP\u CONTENT
来查看
recyclerView
高度,这非常好。我正在这样做,但是我想在向适配器添加(或删除)项目后重新计算高度(从而增加或减少高度)

我特别的
RecyclerView
是从1个项目开始,然后在用户进行选择时添加项目。所以我需要
RecyclerView
布局来增加高度,直到达到一定程度。理想情况下,当列表增加或减少时,平滑动画会出现这种情况

我们如何才能使它在布局后
包装内容

尝试:

recyclerview.requestLayout();

recyclerview.invalidate();

我希望它能与
View.invalidate()
一起工作


如果不起作用,请尝试在父视图上调用
requestLayout
invalidate

选项I

你看到这个了吗

它没有使用recyclerView的
WRAP\u内容
,但它可能会起作用

您还可以创建自己的自定义recyclerView(extends recyclerView),并使用链接中的layoutManager替代那里的
onMeasure()
方法

选项二

在绘制视图之前,请尝试设置布局参数。我还没有检查它是否在recyclerView布局更改时被调用,但如果它被调用,那么它就会工作。类似这样的内容(在活动/片段
onCreate()
/
onCreateView()
方法中:

recyclerView.getViewTreeObserver().addOnPreDrawListener(new ViewTreeObserver.OnPreDrawListener() {
            @Override
            public boolean onPreDraw() { 
                recyclerView.getViewTreeObserver().removeOnPreDrawListener(this);

                YourParentLayoutType.LayoutParams params = (YourParentLayoutType.LayoutParams) recyclerView.getLayoutParams();
                params.height = YourParentLayoutType.LayoutParams.WRAP_CONTENT;
                recyclerView.setLayoutParams(params);

                return true;
            }
        });
使用recyclerView的父布局类型,而不是代码中的
YourParentLayoutType
。 我不确定这在布局刷新时是否有效,但可能值得一试。

使用此类:

请使用23.2.1,因为23.2是一个很好的工具

此外,您是否尝试在
recyclerview
适配器上调用
notifyDataSetChanged
,我认为如果您将wrap\u内容指定为recyclerview的高度,它应该可以毫无问题地展开

否则您可以使用该类:

import android.content.Context;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.View;
import android.view.ViewGroup;

public class MyLinearLayoutManager extends LinearLayoutManager {

    public MyLinearLayoutManager(Context context, int orientation, boolean reverseLayout)    {
        super(context, orientation, reverseLayout);

    }



    private int[] mMeasuredDimension = new int[2];


    @Override
    public void onMeasure(RecyclerView.Recycler recycler, RecyclerView.State state,
                          int widthSpec, int heightSpec) {
        final int widthMode = View.MeasureSpec.getMode(widthSpec);
        final int heightMode = View.MeasureSpec.getMode(heightSpec);
        final int widthSize = View.MeasureSpec.getSize(widthSpec);
        final int heightSize = View.MeasureSpec.getSize(heightSpec);



        int width = 0;
        int height = 0;
        for (int i = 0; i < getItemCount(); i++) {
            if (getOrientation() == HORIZONTAL) {
                measureScrapChild(recycler, i,
                        View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED),
                        heightSpec,
                        mMeasuredDimension);

                width = width + mMeasuredDimension[0];
                if (i == 0) {
                    height = mMeasuredDimension[1];
                }
            } else {
                measureScrapChild(recycler, i,
                        widthSpec,
                        View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED),
                        mMeasuredDimension);

                height = height + mMeasuredDimension[1];
                if (i == 0) {
                    width = mMeasuredDimension[0];
                }
            }
        }


        switch (widthMode) {
            case View.MeasureSpec.EXACTLY:
                width = widthSize;
            case View.MeasureSpec.AT_MOST:
            case View.MeasureSpec.UNSPECIFIED:
        }

        switch (heightMode) {
            case View.MeasureSpec.EXACTLY:
                height = heightSize;
            case View.MeasureSpec.AT_MOST:
            case View.MeasureSpec.UNSPECIFIED:
        }

        int widthDesired = Math.min(widthSize,width);
        setMeasuredDimension(widthDesired, height);
    }

    private void measureScrapChild(RecyclerView.Recycler recycler, int position, int widthSpec,
                                   int heightSpec, int[] measuredDimension) {
        View view = recycler.getViewForPosition(position);
        // For adding Item Decor Insets to view
        super.measureChildWithMargins(view, 0, 0);
        RecyclerView.LayoutParams p = (RecyclerView.LayoutParams) view.getLayoutParams();
        int childWidthSpec = ViewGroup.getChildMeasureSpec(
                widthSpec,
                getPaddingLeft() + getPaddingRight() + getDecoratedLeft(view) + getDecoratedRight(view),
                p.width);
        int childHeightSpec = ViewGroup.getChildMeasureSpec(
                heightSpec,
                getPaddingTop() + getPaddingBottom() + getDecoratedTop(view) + getDecoratedBottom(view) ,
                p.height);
        view.measure(childWidthSpec, childHeightSpec);

        // Get decorated measurements
        measuredDimension[0] = getDecoratedMeasuredWidth(view) + p.leftMargin + p.rightMargin;
        measuredDimension[1] = getDecoratedMeasuredHeight(view) + p.bottomMargin + p.topMargin;
        recycler.recycleView(view);
        }
    }
导入android.content.Context;
导入android.support.v7.widget.LinearLayoutManager;
导入android.support.v7.widget.RecyclerView;
导入android.view.view;
导入android.view.ViewGroup;
公共类MyLinearLayoutManager扩展了LinearLayoutManager{
公共MyLinearLayoutManager(上下文上下文、int方向、布尔反转){
超级(上下文、方向、反转);
}
私有int[]mMeasuredDimension=新int[2];
@凌驾
测量时的公共空隙(RecyclerView.Recycler Recycler,RecyclerView.State,
整数宽度规格、整数高度规格){
最终int-widthMode=View.MeasureSpec.getMode(widthmspec);
最终int heightMode=View.MeasureSpec.getMode(heightSpec);
最终int-widthSize=View.MeasureSpec.getSize(widthSpec);
最终int heightSize=View.MeasureSpec.getSize(heightSpec);
整数宽度=0;
整数高度=0;
对于(int i=0;i
如何使用新的LayoutManger根据RecyclerView调整自身大小

RecyclerView小部件为创建列表和网格以及支持动画提供了一个高级而灵活的基础。此版本为LayoutManager API带来了一个激动人心的新功能:自动测量!这允许RecyclerView根据其内容的大小调整其大小。这意味着