LinearLayout.onMeasure--事例说明

将LinearLayout中代码Copy了一份存在本地,然后再在里面加了几个子View,打印出来LinearLayout.onMeasure中的那些变量的值

  1. 如下图所示,LinearLayout中有4个子View

    示例1

    打印出来的值为:
    示例1打印出的值

    其中可以看出由于最顶层的LinearLayout设置的是65dip,换算到本人手机上的是65*3=195px,由于自定义的LinearLayout的layout_height设置的是wrap_content,所以得到的MeasureSpec.Mode为AT_MOST,而在第一个TextView的layout_height设置的是wrap_content,所以在第一个TextView进行measure的时候会根据getChildMeasureSpec来进行子View的MeasureSpec的计算,因为是AT_MOST的,所以它的宽度最大只能是195,与父View相同。而第二个和第三个View的height为0,是因为在getChildMeasureSpec中,父View的MeasureSpec.Mode为AT_MOST,而子View的lp.height是MATCH_PARENT,所以计算的时候会得到0.而最后一个子View,是因为layout_height指定了是1920dip,所以在getChildMeasureSpec的时候,会直接把1920dip转换成size,然后Mode为MeasureSpec.EXACTLY,所以在获取大小的时候,得到的是5760。

  2. 第二种情况和上面的情况只变了一个地方,是LinearLayout的wrap_content变成了match_parent,

示例2

打印出来的值为:


示例2打印出的值

可以看到和上面的区别只是MeasureSpec.Mode从AT_MOST变成了EXACTLY

  1. 有weight的情况
设置Weight属性

打印出的结果:


Paste_Image.png

其中Delta在源码中表示超出的部分,shared代表着这个View还需要分担多少高度

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容