一起Talk Android吧(第四百六十八回:实现自定义View中的布局功能)


各位看官们大家好,上一回中咱们说的例子是"实现自定义ViewGroup中的测量功能",这一回中咱们说的例子是" 实现自定义View中的布局功能"。闲话休提,言归正转,让我们一起Talk Android吧!

功能介绍

布局功能是自定义View中的主要功能,布局主要是规划View在父View中的的位置,更准确的说是计算View的宽度和高度。实现此功能只需要重写View类的onLayout()方法就可以实现布局功能。布局完成后我们就可以获取到View的的宽度和高度了。具体的方法是使用getWidth()和getHeight()方法。

通常我们只有在继承ViewGroup的子类时才需要实现布局功能,继承view类时不需要实现布局功能。这点我们在介绍自定义View的思路时也说过。因此我们在本章回说的自定义View是指继承自
ViewGroup的子类,由于ViewGroup是View的子类,因此我们将其泛称为View。

重写方法

重写onLayout()方法的思路分两步:首先遍历当前ViewGroup的所有子view,并且计算出子view的宽度或者高度,然后把所有子view的宽度或者高度累加起来就是当前ViewGroup的宽度或者高度,这里需要注意,如果当前ViewGroup的方向是垂直方向,那么所有子view高度累加起来就是ViewGroup的高度,而ViewGrop的宽度是所有子View中最宽的值。如果当前ViewGroup的方向是水平方向,那么所有子view宽度累加起来就是ViewGroup的宽度,而ViewGrop的高度是所有子View中最高的值。

示例代码

介绍完如何重写onLayout()方法后,我们通过代码来演示具体的实现过程:

int top,left;
top = left = 0;

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

    //计算子控件的长宽
    child.layout(left,top,childWidth+left,childHeight+top);

    if(垂直布局)  {
        top += childHeight;
    }else {
        left += childWidth;
    }
}

看官们,关于"实现自定义View中的布局功能"的例子咱们就介绍到这里,欲知后面还有什么例子,且听下回分解!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

talk_8

真诚赞赏,手有余香

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值