LinearLayout.onMeasure--事例说明

2018-10-24 15:05:04 浏览数 (1)

将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。

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

示例2

打印出来的值为:

示例2打印出的值

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

  1. 有weight的情况

设置Weight属性

打印出的结果:

Paste_Image.png

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

0 人点赞