layout_weight常见解析

布局权重详解
本文详细解析了在Android开发中使用LinearLayout的layout_weight属性时的各种场景及其影响。包括如何通过layout_weight实现不同控件间的比例分配、解决对齐问题、以及特定布局设置的影响。

布局中若想某几个控件在水平方向以某种比例显示,可做如下操作:

     以三个Textview为例子,想要宽度是1:2:2:

       分别设置:layout_width="0db",layout_weight=1;、

                            layout_width="0db",layout_weight=2;

                           layout_width="0db",layout_weight=2;

会遇到的问题:

 (1)若第一个TextView因为宽度不够,分行显示了,结果发现该Textview与另两个没有对齐,该如何对齐?

          注意下可以发现他的第一行还是与其他两个Textview是对齐的,原因是Textview会参考父类的baseline(基线),因此解决以上问题的方法是:

  设置LinearLayout的layout_Aligned=“fasle"



    (2)假设将第一个Textview的layout_width=wrap_content,会不会影响layout_weight?

            修改后可以看到三个textview没有按周1:2:2布局,看来的确是影响到了。

        这反映了如下问题:

             LinearLayout的Layout_weight属性,首先按照控件申明的尺寸进行分配,然后再将剩下的尺寸按照weight分配


(3)将三个textview的宽度都设为match_parent,会如何显示?

          可以看到:Textview比例为1的控件所占的比例反而更大了,原因是;

           LinearLayout的Layout_weight属性,首先按照控件申明的尺寸进行分配,然后再将剩下的尺寸按照weight分配

         三个控件申明宽度一样,计算过程如下:

           假设手机屏宽480dp:

             申明的尺寸为480(match_parent),剩下的尺寸为:480-3*480= -2*480;

             第一个textview宽度:480+(-2*480)*1/5=288;

             第二,三均为: 480+(-2*480)*2/5=96;

      可以看出第一个TEXTVIEWwidth值更大

 结论:控件宽度=申明的尺寸+父控件剩余尺寸*比例


(4)若一行只有一个控件,如何能占整个宽度的一半?

         控件申明:layout_width="0db",layout_weight=1;

         LinearLayout申明:weightSum="2";


以上几点对于高度也适用。


另外:带有layout_开头的属性都是交给父容器,没有layout_开头的都是本身的属性

             

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="100dp"> <LinearLayout android:layout_width="0dp" android:layout_weight="1" android:layout_height="match_parent" android:orientation="vertical"> <TextView android:id="@+id/title" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1" android:textSize="16sp"/> <TextView android:id="@+id/author" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1" android:textColor="@color/gray"/> <TextView android:id="@+id/time" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1" android:textColor="@color/gray"/> <TextView android:id="@+id/need" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1" android:textColor="@color/gray"/> </LinearLayout> <com.google.android.material.button.MaterialButton android:layout_width="60dp" android:layout_height="100dp" android:layout_marginHorizontal="12dp" app:cornerRadius="6dp" android:textSize="20sp" android:text="报名" android:textStyle="bold"/> </LinearLayout> 如何解决Indicates how much of the extra space in the LinearLayout is allocated to the view associated with these LayoutParams. Specify 0 if the view should not be stretched. Otherwise the extra pixels will be pro-rated among all views whose weight is greater than 0.
03-11
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值