layout_weight及常见属性解析

layout_weight在使用中遇到的问题

1.在一个横向的linearLayout中有三个TextView,layout_width都是0dp,layout_weight分别是1,2,3,内容分别是111111111111111,2,3运行发现,一长串的文本和第2,3个textView的底部是不对齐的,原因是因为TextView在LinearLayout中会参考父类的baseline,如何解决呢?
需要将textview所在的linearlayout的baselineAligned = “false”

2.在上述布局的基础上,修改第一个textview的layout_width属性为wrap_content,运行发现三个textView并没有按照layout_weight的比例展示出来。
说明:LinearLayout中的layout_weight属性,首先按照控件声明的尺寸进行分配,然后再将剩下的尺寸按weight(1:2:3)分配。

3.修改第一个的布局中的三个TextView的layout_width均为match_parent,然后将layout_weight修改成1:2:2,运行发现完全不是想要的结果。
这里还利用2中的说明:首先按照控件声明的尺寸进行分配,然后再将剩下的尺寸按weight分配。
假设外层LinearLayout的width为480
那么剩余的尺寸是:480-480 x 3 = -480 x 2;
三个TextView占的比例分别是1/(1+2+2)、2/(1+2+2)、2/(1+2+2) 即1/5、2/5 、2/5
TextView 1:480+(-480 x 2)*(1/5)= 480 x(3/5)
TextView 2、3:480 +(-480 x 2)(2/5)= 480 x(1/5)
结论:控件宽度+父控件剩余宽度 x 比例 (父控件剩余宽度是可以小于0的)

4.在linearlayout中只有一个TextView,并且想使这个textView占据屏幕的一半,那么可以在Linearlayout中声明属性 android:weightSum = 2,将TextView的width = 0dp,weight = 1;就可以实现效果。

5.TextView的layout_width,layout_height,layout_weight等以layout_开头的属性都是交给其父容器设置的。不带layout_开头的属性,是控件本身的属性。所以layout_gravity是指父布局控制子view的布局显示,而view本身的gravity是指view控制其自身内容的显示。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值