android layout_weight属性学习巩固



    一年一年又一年,时间过得真心快,已经是2015年11月份了,但是我等屌丝依旧在

梦想的道路上苦苦地摸索,步入正题

大家都使用过线性布局,layout_weight属性

一般我们会把相应的layout_width(水平布局)或者layout_height(垂直的)设为0dp,来保证layout_weight的正常使用。比如在一个水平的线性布局里,放入三个textView

 

<!--StartFragment -->

android layout_weight属性学习巩固_第1张图片

得到的结果是


<!--StartFragment -->

android layout_weight属性学习巩固_第2张图片
 
是不是觉得怪怪的,不应该是这样吗?


android layout_weight属性学习巩固_第3张图片

原因:textView对于控件在线性布局里不是水平的,=而里面的文字(内容)确实水平的,因此我们可以修改父容器的baseLineAligned=“false”,来告诉子控件,让子控件水平,得到我们预期的效果。

 

情景二:修改

当我们把第一个textview设为自适应


android layout_weight属性学习巩固_第4张图片
 得到的结果是这样的


 
android layout_weight属性学习巩固_第5张图片
 什么情况?

是因为LinearLayout属性首先按照控件声明的尺寸进行分配,于是textView1的内容就充满了,让后剩下的按照weight值的1:2:3d的比例分配。

情景三:

当全部为fill_parent时,


android layout_weight属性学习巩固_第6张图片
 结果wei:
 

layout_weight最小的确反而拥有最大的尺寸

分析:根据二中给出的结论,控件先按照声明的尺寸分配,剩下的尺寸按照比例分配
 

假设屏幕宽度为480dp

则剩余的尺寸为480-480*3=-960

于是textView1为480+(-960)*0.2

textView2,3分别为480+(-960)*0.4和480+(-960)*0.6

所以出现了这种不可思议的情况,有没有很酷

结论:控件宽度+剩余的部分*比例

 

拓展:linearlayout里只有一个控件,但是却想只占用屏幕一半的面积,可以把linearlayout设属性weightSum=2,texview layout_weight=1

layout_XXX表示在相应的布局,XXX则表示控件本身内容

你可能感兴趣的:(面试,layout-weight)