当前位置: 代码迷 >> Android >> android layout_weight属性学习加固
  详细解决方案

android layout_weight属性学习加固

热度:28   发布时间:2016-04-27 22:22:26.0
android layout_weight属性学习巩固



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

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

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

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

?

<!--StartFragment -->

得到的结果是


<!--StartFragment -->


?
是不是觉得怪怪的,不应该是这样吗?


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

?

情景二:修改

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



?得到的结果是这样的


?

?什么情况?

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

情景三:

当全部为fill_parent时,



?结果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则表示控件本身内容
  相关解决方案