自定义View制作简单的流式布局(搜索历史记录)

本文介绍了一个自定义的ViewGroup布局实现方式,该布局能够根据子View的数量和大小自动调整布局,确保子View能够在一行排不下时换行,并且均匀分布。通过MeasureSpec计算子View的尺寸,使用onMeasure和onLayout方法完成布局绘制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class View3 extends ViewGroup {
    private int hsize;
    private int wsize;
    private int childh;
    private int childw;

    public View3(Context context) {
        super(context);
    }
    public View3(Context context, AttributeSet attrs) {
        super(context, attrs);
    }
    public View3(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 top = 10;
        int left = 10;
        
        int hmode = MeasureSpec.getMode(heightMeasureSpec);
        hsize = MeasureSpec.getSize(heightMeasureSpec);
        wsize = MeasureSpec.getSize(widthMeasureSpec);

        switch (hmode){
            case MeasureSpec.AT_MOST:
                //循环测量子View的宽高
                for (int i=0;i<getChildCount();i++){
                    childw = getChildAt(i).getMeasuredWidth();
                    childh = getChildAt(i).getMeasuredHeight();
                    //如果左边距+View宽+右边距>View宽
                 if (left + childw+10>wsize){
                     top +=(childh+10);
                     left=10;
                 }
                    left+=(childw+10);
                }
                //累计最后一行
                top +=(childh+10);
                break;
        }
        setMeasuredDimension(wsize,top);
    }
    @Override
    protected void onLayout(boolean changed, int l, int t, int r, int b) {
    int left=10;
    int top=10;
        for (int i=0;i<getChildCount();i++){
            childw = getChildAt(i).getMeasuredWidth();
            childh = getChildAt(i).getMeasuredHeight();
            if (left + childw+10>wsize){
                top +=(childh+10);
                left=10;
                getChildAt(i).layout(left,top,left+childw,top+childh);
            }else{
                getChildAt(i).layout(left,top,left+childw,top+childh);
            }
            left+=(childw+10);
        }
    }
    //添加事件点击事件
    @Override
    public boolean onTouchEvent(MotionEvent event) {
        return super.onTouchEvent(event);
    }
}

点击添加历史搜索记录

  butsou.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                String keywork = edit_sou.getText().toString();
                TextView textView = new TextView(getActivity());
               // textView.setTag(name);
                textView.setText(keywork);
                view_self.addView(textView);
                view_self.requestLayout();
                showPresenter.ShowData(keywork, page, count);
            }
        });
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值