流式布局的简单实现

public class MyFlow extends ViewGroup {
    public MyFlow(Context context) {
        super(context);
    }

    public MyFlow(Context context, AttributeSet attrs) {
        this(context, attrs,0);
    }

    public MyFlow(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);

        //测量所有孩子的宽高
        measureChildren(widthMeasureSpec, heightMeasureSpec);

        int widthMode = MeasureSpec.getMode(widthMeasureSpec);
        int widthSize = MeasureSpec.getSize(widthMeasureSpec);//AT-MOST
        int heightMode = MeasureSpec.getMode(heightMeasureSpec);
        int heightSize = MeasureSpec.getSize(heightMeasureSpec);

        int width = 0;
        int height = 0;
        int lineWidth = 0;
        //int lineHeight = 0;
        int totalHeight = 0;//累加的高度
        View childView;
        int childWidth = 0;
        int childHeight = 0;


        for (int i = 0; i < getChildCount(); i++) {
            childView = getChildAt(i);
            childWidth = childView.getMeasuredWidth();
            childHeight = childView.getMeasuredHeight();

            //
            if (childWidth > widthSize) {
                //Log.d(TAG, "onMeasure: 太大了");
            }

            //测量布局的宽
            //换行/不换行
            if (childWidth + lineWidth > widthSize) {
                //换行
                width = widthSize;
                totalHeight += childHeight;

                //第一个
                //lineHeight = childHeight;
                lineWidth = childWidth;
            } else {
                //不换行

                lineWidth += childWidth;

                //lineHeight = Math.max(lineHeight, childHeight);

                width = Math.max(width, lineWidth);
            }
            //测量高度
            if (i == getChildCount() - 1) {
                totalHeight += childHeight;
                height = totalHeight;
            }
        }

        width = widthMode == MeasureSpec.EXACTLY ? widthSize : width;
        height = heightMode == MeasureSpec.EXACTLY ? heightSize : height;

        setMeasuredDimension(widthSize, heightSize);
    }

    @Override
    protected void onLayout(boolean changed, int l, int t, int r, int b) {
        int lineWidth = 0;
        //int lineHeight = 0;
        int totalHeight = 0;//累加的高度
        View childView;
        int childWidth = 0;
        int childHeight = 0;


        for (int i = 0; i < getChildCount(); i++) {
            childView = getChildAt(i);
            childWidth = childView.getMeasuredWidth();
            childHeight = childView.getMeasuredHeight();


            //测量布局的宽
            //换行/不换行
            if (childWidth + lineWidth > getMeasuredWidth()) {
                //换行
                totalHeight += childHeight;
                lineWidth = 0;
                childViewLayout(childView, lineWidth, totalHeight, lineWidth + childWidth, totalHeight + childHeight);
                //第一个
                //lineHeight = childHeight;
                lineWidth = childWidth;
            } else {
                //不换行
                childViewLayout(childView, lineWidth, totalHeight, lineWidth + childWidth, totalHeight + childHeight);

                lineWidth += childWidth;

                //lineHeight = Math.max(lineHeight, childHeight);

            }
        }
    }

    public void childViewLayout(View childView, int l, int t, int r, int b) {
        childView.layout(l, t, r, b);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值