自定义View实现LinearLayout

本文介绍了如何通过继承ViewGroup自定义一个纵向布局的LinearLayout。首先展示了实现效果,然后详细讲解了onMeasure过程,其中主要关注对子View的测量和宽高的计算。接着讨论了onLayout方法,它是ViewGroup的核心,负责子View的定位。最后提到ViewGroup的onDraw默认不被调用的情况。
摘要由CSDN通过智能技术生成

上一篇:自定义View实现TextView

自定义View实现LinearLayout

LinearLayout是我们常用的布局之一,下面我们通过继承ViewGroup来自己写一个具有纵向布局的LinearLayout。

先来看效果图:

onMeasure

这里我们新建了一个类名为MyLinearLayout,其中我们重写了onMeasure函数用于处理当前View的大小。

这里主要对第二部进行说明,其他内容在上一篇已说过这里不再介绍,文章顶部直接导航到上一篇。

在第二部中我们循环所有的子View,并使用getChildAt函数通过索引拿到特定View的实例,紧接着调用从ViewGroup继承的measureChild函数,直接将我们的onMeasure中的两个参数传入。紧接着我们需要将宽高保存一下,宽度我们取最大值,高度进行累加,如果是横向布局就反过来高度取最大值,长度累加。最后设置尺寸即可。

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

    public MyLinearLayout(Context context, AttributeSet attrs) {
   
        super(context, attrs);
    }

    @Override
    protected void onMeasure
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值