将LinearLayout中代码Copy了一份存在本地,然后再在里面加了几个子View,打印出来LinearLayout.onMeasure中的那些变量的值
-
如下图所示,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。 -
第二种情况和上面的情况只变了一个地方,是LinearLayout的wrap_content变成了match_parent,
打印出来的值为:
示例2打印出的值
可以看到和上面的区别只是MeasureSpec.Mode从AT_MOST变成了EXACTLY
- 有weight的情况
打印出的结果:
Paste_Image.png
其中Delta在源码中表示超出的部分,shared代表着这个View还需要分担多少高度
网友评论