layout_weight和weightSum

在编写HTML页面的时候,为了编写出多分辨率适配的页面,通常不会使用固定的像素,而是使用百分比。在Android中,layout_weight属性的功能就与HTML百分比布局类似。

layout_weight表示占用容器剩余空间的比例,而容器有个属性为weightSum表示比例的总数。比如下面的布局文件:

<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
             android:orientation="horizontal"
             android:layout_width="match_parent"
             android:layout_height="match_parent"
             android:weightSum="1">
    <Button
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
            android:text="ButtonA"
           android:id="@+id/button"/>
    <Button
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
            android:layout_weight="0.5"
            android:text="ButtonB"
           android:id="@+id/button2"/>
</LinearLayout>

我们来分析一下,容器的weightSum属性为1ButtonA的宽度为"wrap_content"ButtonB的宽度为"wrap_content"ButtonBlayout_heigh"0.5",那么ButtonB的实际宽度为:"wrap_content"+容器剩余空间的一半。而剩余空间就是容器在放完ButtonA(宽度为wrap_content)和ButtonB(宽度为wrap_content)之后所剩下的空间。那么上面的布局文件所得到的界面就是如下所示了。


 

如果这个时候把ButtonBlayout_weight属性改为0,则界面就变成:



一般情况下,我们使用layout_weight时会将元素的layout_widght属性(横向布局时,纵向布局则是是layout_height属性)设置为0,即该元素占据的剩余空间为容器摆放完其他元素(不包含该元素本身,因为该元素的layout_widght0)之后的空间。具体的属性设置还得看项目中的具体需求。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值