2012-7-17 android:layout_weight

androidlayout_weight

是用于给一个线性布局(LinearLayout)中的诸多视图的重要度赋值。

所有的视图都有一个layout_weight值,默认为零,意思是需要显示多大的视图就占据多的的屏幕空间。若赋值高于零又是怎么样的呢?

在网上有很多关于layout_weight的学习资料,网上介绍的都大同小异,以为该学到的都学到的时候,一实践就发现了一些问题。以下一段是网上关于layout_weight值大于零的显示效果的说法。

如果一行中有两个等长的文本框,那么他们的android:layout_weight值可以是同为1。如果一行中有两个不等长的文本框,那么他们的android:layout_weight值分别为12,那么第一个文本框将占据剩余空间的三分之二,第二个文本框将占据剩余空间中的三分之一。android:layout_weight遵循数值越小,重要度越高的原则。

网上说法都没有提到layout_width/layout_height的值,事实上layout_weight的属性值跟layout_width/layout_height有很大的关系,下面是我结合网上学习和个人实践后作出的有关layout_weight使用的小结。当然正不正确读者自己实践证明就知道。

首先一点LinearLayout中要让layout_weight生效,需要父层或父父层的相应layout_width/layout_height=fill_parent”,否则“wrap_content”会压缩到最小足够空间。

第二所有的视图都有一个layout_weight值,默认为零,需要显示多大的视图就占据多的的屏幕空间。

第三:当layout_weight值大于零是情况有二。以三个并列的文本框为例说明如下,其中layout_width影响layout_weight,代码如下:

<?xml version="1.0" encoding="UTF-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

    android:layout_width="fill_parent"

    android:layout_height="wrap_content"

    android:orientation="horizontal" >

 

    <TextView

        android:background="#ff0000"

        android:layout_width="**"

        android:layout_height="wrap_content"

        android:text="1"

        android:textColor="@android:color/white"

        android:layout_weight="1"/>

    <TextView

        android:background="#cccccc"

        android:layout_width="**"

        android:layout_height="wrap_content"

        android:text="2"

        android:textColor="@android:color/black"

        android:layout_weight="2" />

     <TextView

        android:background="#ddaacc"

        android:layout_width="**"

        android:layout_height="wrap_content"

        android:text="3"

        android:textColor="@android:color/black"

        android:layout_weight="3" />

</LinearLayout>

情况一:

三个文本框的都是layout_width=fill_parent”时,其权重赋值遵循数值越小,重要度越高的原则。这种情况下,没有设置layout_weight的话,第一个组件将占用余下的空间,那么后面的组件就显示不出来。

  •    都为 1 的话就是平分

 

  (图一)

 

  •   为 1 2 3 的话,只有前面两个文本框显示,比例为 2 1 (如图一)。

 

  (图二)

  •   为 1 2 2 的话,分成 5 份,三个文本框都显示,比例为 3:1:1 (如图三);
    (图三)
  •   为 1 3 3 的话,分成 7 份,三个文本框都显示,比例为 5:1:1

 

  (图四)

 

   注意:这种情况适合两个组件设置权重,多了的话不好预知显示结果,设置不好的话有些组件无法显示。 

情况二:

三个文本框的都是layout_width=wrap_content”时,其值表示占用剩余空间的比例。

  •   为 1 2 3 的话,分成 6 份,三文本框显示,比例 1:2:3 (如图五)

 (图五)

情况三:

当三个文本框中的layout_width的值既有fill_parent又有wrap_content时,以fill_parent优先。

 

 

结束语不同情况显示的都不同,有些虽然别人介绍,我们以为懂了,可是就有那么多小细节没有考虑到导致结果相差甚远,所以每个效果只有自己试了才知道,只有出错了才了解,只有成功了才确定。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值