android之layout_weight详解

本文解释了Android布局中layout_weight属性的作用及其使用方法。通过实例展示了如何利用该属性来分配线性布局内各视图的空间占比。
layout_weight 用于给一个线性布局中的诸多视图的重要度赋值。 
     所有的视图都有一个layout_weight值,默认为零,意思是需要显示 
     多大的视图就占据多大的屏幕空 间。若赋一个高于零的值,则将父视 
     图中的可用空间分割,分割大小具体取决于每一个视图的layout_weight 
       值以及该值在当前屏幕布局的整体 layout_weight值和在其它视图屏幕布 
     局的layout_weight值中所占的比率而定。 
     举个例子:比如说我们在 水平方向上有一个文本标签和两个文本编辑元素。 
    该文本标签并无指定layout_weight值,所以它将占据需要提供的最少空间。 
    如果两个文本编辑元素每一个的layout_weight值都设置为1,则两者平分 
    在父视图布局剩余的宽度(因为我们声明这两者的重要度相等)。如果两个  
   文本编辑元素其中第一个的layout_weight值设置为1,而第二个的设置为2, 
   则剩余空间的三分之二分给第一个,三分之一分给第二个(数值越小,重要度越高)。 

看例子

<?xml version="1.0" encoding="utf-8"?>   
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="vertical"  
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent"  
    >   
  <LinearLayout   
      android:orientation="horizontal"  
      android:layout_width="fill_parent"  
      android:layout_height="fill_parent"  
      android:layout_weight="1">   
      <TextView   
          android:text="redwwwwwww"  
          android:gravity="center_horizontal"  
          android:background="#aa0000"  
          android:layout_width="wrap_content"  
          android:layout_height="fill_parent"  
          android:layout_weight="1"/>   
      <TextView   
          android:text="green"  
          android:gravity="center_horizontal"  
          android:background="#00aa00"  
          android:layout_width="wrap_content"  
          android:layout_height="fill_parent"  
          android:layout_weight="2"/>   
      <TextView   
          android:text="blue"  
          android:gravity="center_horizontal"  
          android:background="#0000aa"  
          android:layout_width="wrap_content"  
          android:layout_height="fill_parent"  
          android:layout_weight="3"/>   
      <TextView   
          android:text="yellow"  
          android:gravity="center_horizontal"  
          android:background="#aaaa00"  
          android:layout_width="wrap_content"  
          android:layout_height="fill_parent"  
          android:layout_weight="4"/>   
  </LinearLayout>   
</LinearLayout>  
 注:本文为转载

源地址:http://www.cnblogs.com/alpha-bowen/archive/2011/03/02/1969343.html

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:background="#ECECEC" android:padding="10dp"> <LinearLayout android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="0.4" android:orientation="horizontal"> <ImageView android:padding="2dp" android:layout_width="30dp" android:layout_height="30dp" android:src="@drawable/img_jisuanqi"/> <TextView android:layout_width="0dp" android:layout_height="30dp" android:layout_weight="1" android:text="计算器" android:textColor="#000000" android:textSize="15sp" android:layout_marginLeft="8dp" android:gravity="center_vertical"/> <ImageView android:layout_width="60dp" android:layout_height="30dp" android:src="@drawable/img_jianhao" android:padding="6dp"/> <ImageView android:layout_width="60dp" android:layout_height="30dp" android:padding="6dp" android:src="@drawable/img_square"/> <ImageView android:layout_width="60dp" android:layout_height="30dp" android:padding="6dp" android:src="@drawable/img_cha"/> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="0.6" android:orientation="horizontal" android:layout_marginTop="10dp" android:gravity="center"> <ImageView android:padding="6dp" android:layout_width="30dp" android:layout_height="30dp" android:src="@drawable/img_gang"/> <TextView android:layout_width="wrap_content" android:layout_height="match_parent" android:text="标准" android:textColor="#000000" android:textSize="30sp" android:textStyle="bold" android:layout_marginLeft="8dp" android:gravity="center_vertical"/> <ImageView android:layout_width="0dp" android:layout_height="30dp" android:layout_weight="1" android:scaleType="fitStart" android:src="@drawable/img_top"/> <ImageView android:layout_width="30dp" android:layout_height="30dp" android:padding="6dp" android:src="@drawable/img_lishi"/> </LinearLayout> <HorizontalScrollView android:id="@+id/scrollView_1" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="0.5" android:scrollbars="none" android:background="@drawable/biankuang"> <EditText android:textColor="#808080" android:id="@+id/editText_1" android:layout_width="wrap_content" android:layout_height="match_parent" android:textSize="30sp" android:focusable="false" android:focusableInTouchMode="false" android:clickable="true" android:cursorVisible="false" android:background="@null" android:maxLines="1" android:scrollHorizontally="true" android:inputType="none" android:layout_gravity="right|center"/> </HorizontalScrollView> <HorizontalScrollView android:id="@+id/scrollView" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1" android:background="@drawable/biankuang" android:scrollbars="none"> <EditText android:id="@+id/editText" android:layout_width="wrap_content" android:layout_height="match_parent" android:layout_gravity="right|center" android:background="@null" android:clickable="true" android:cursorVisible="false" android:focusable="false" android:focusableInTouchMode="false" android:inputType="none" android:maxLines="1" android:scrollHorizontally="true" android:text="0" android:textSize="60sp" /> </HorizontalScrollView> <LinearLayout android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="0.5" android:orientation="horizontal"> <TextView android:id="@+id/tv_mc" android:layout_width="0dp" android:layout_height="30dp" android:layout_weight="1" android:gravity="center" android:text="MC" android:textSize="15dp" android:textColor="#808080"/> <TextView android:id="@+id/tv_mr" android:layout_width="0dp" android:layout_height="30dp" android:layout_weight="1" android:gravity="center" android:text="MR" android:textSize="15dp" android:textColor="#808080"/> <TextView android:id="@+id/tv_m_plus" android:layout_width="0dp" android:layout_height="30dp" android:layout_weight="1" android:gravity="center" android:text="M+" android:textColor="@color/black" android:textSize="15dp" /> <TextView android:id="@+id/tv_m_minus" android:layout_width="0dp" android:layout_height="30dp" android:layout_weight="1" android:gravity="center" android:text="M-" android:textColor="@color/black" android:textSize="15dp" /> <TextView android:id="@+id/tv_ms" android:layout_width="0dp" android:layout_height="30dp" android:layout_weight="1" android:gravity="center" android:text="MS" android:textColor="@color/black" android:textSize="15dp" /> <TextView android:layout_width="0dp" android:layout_height="30dp" android:layout_weight="1" android:gravity="center" android:text="M⋁" android:textSize="15dp" /> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="7" android:orientation="vertical"> <LinearLayout android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1"> <Button android:id="@+id/btn_symbol_percent" android:layout_gravity="center" android:text="%" android:textSize="20sp" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/rounded_button_background" /> <Button android:id="@+id/btn_clear_entry" android:layout_gravity="center" android:text="CE" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/rounded_button_background"/> <Button android:id="@+id/btn_clear" android:layout_gravity="center" android:text="C" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/rounded_button_background"/> <ImageView android:id="@+id/btn_clear_image" android:layout_gravity="center" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:padding="10dp" android:background="@drawable/rounded_button_background" android:scaleType="fitCenter" android:src="@drawable/img_qingchu" /> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1"> <Button android:id="@+id/btn_symbol_x_inverse" android:layout_gravity="center" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/rounded_button_background" android:text="1/x" android:textColor="@color/black" android:textSize="20sp"/> <Button android:id="@+id/btn_symbol_square" android:layout_gravity="center" android:text="x²" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/rounded_button_background" /> <ImageView android:id="@+id/btn_symbol_square_root" android:layout_gravity="center" android:src="@drawable/img_sqrt" android:padding="18dp" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/rounded_button_background"/>\ <Button android:id="@+id/btn_symbol_divide" android:layout_gravity="center" android:text="÷" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/rounded_button_background"/> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1"> <Button android:id="@+id/btn_num_7" android:layout_gravity="center" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background" android:text="7" android:textColor="@color/black" android:textSize="20sp" /> <Button android:id="@+id/btn_num_8" android:layout_width="0dp" android:layout_height="55dp" android:layout_gravity="center" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background" android:text="8" android:textColor="@color/black" android:textSize="20sp" /> <Button android:id="@+id/btn_num_9" android:layout_gravity="center" android:text="9" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background"/>\ <Button android:id="@+id/btn_symbol_multiply" android:layout_gravity="center" android:text="×" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/rounded_button_background"/> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1"> <Button android:id="@+id/btn_num_4" android:layout_gravity="center" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background" android:text="4" android:textColor="@color/black" android:textSize="20sp" /> <Button android:id="@+id/btn_num_5" android:layout_gravity="center" android:text="5" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background" /> <Button android:id="@+id/btn_num_6" android:layout_width="0dp" android:layout_height="55dp" android:layout_gravity="center" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background" android:text="6" android:textColor="@color/black" android:textSize="20sp" /> <Button android:id="@+id/btn_symbol_minus" android:layout_gravity="center" android:text="-" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/rounded_button_background"/> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1"> <Button android:id="@+id/btn_num_1" android:layout_gravity="center" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background" android:text="1" android:textColor="@color/black" android:textSize="20sp" /> <Button android:id="@+id/btn_num_2" android:layout_gravity="center" android:text="2" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background" /> <Button android:id="@+id/btn_num_3" android:layout_gravity="center" android:text="3" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background"/>\ <Button android:id="@+id/btn_symbol_plus" android:layout_gravity="center" android:text="+" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/rounded_button_background"/> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1"> <Button android:id="@+id/btn_symbol_plus_minus" android:layout_gravity="center" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background" android:text="+/-" android:textColor="@color/black" android:textSize="20sp" /> <Button android:id="@+id/btn_num_0" android:layout_gravity="center" android:text="0" android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background" /> <Button android:id="@+id/btn_num_dot" android:layout_gravity="center" android:text="." android:textSize="20sp" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="55dp" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/other_button_background"/>\ <Button android:id="@+id/btn_symbol_equals" android:layout_width="0dp" android:layout_height="55dp" android:layout_gravity="center" android:layout_margin="3dp" android:layout_weight="1" android:background="@drawable/equals" android:text="=" android:textColor="@color/black" android:textSize="20sp" /> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1.2"> </LinearLayout> </LinearLayout> </LinearLayout>告诉我怎么在这个页面找到所对应的按钮
10-21
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值