Android 使用 TableLayout 布局拉伸宽度

布局文件

   1.0" encoding="utf-8"?> 
   
    http://schemas.android.com/apk/res/android" android:orientation="
    vertical" android:layout_width="
    fill_parent" android:layout_height="
    fill_parent"> 
    
     match_parent" android:layout_height="
     match_parent"> 
      
      
       @+id/et_led" android:layout_width="
       fill_parent" android:digits="
       1234567890.+-*/=%/n/t()" android:text="
       " android:layout_span="
       4" /> 
      
      
      
      (" android:id="@+id/btn_LeftParenthesis"> 
      )" android:id="@+id/btn_RightParenthesis"> 
      *" android:id="@+id/btn_x"> 
      back" android:id="@+id/btn_back"> 
      
      
      7" android:id="@+id/btn_7"> 
      8" android:id="@+id/btn_8"> 
      9" android:id="@+id/btn_9"> 
      %" android:id="@+id/btn_mod"> 
      
      
      4" android:id="@+id/btn_4"> 
      5" android:id="@+id/btn_5"> 
      6" android:id="@+id/btn_6"> 
      /" android:id="@+id/btn_div"> 
      
      
      1" android:id="@+id/btn_1"> 
      2" android:id="@+id/btn_2"> 
      3" android:id="@+id/btn_3"> 
      -" android:id="@+id/btn_sub"> 
      
      
      0" android:id="@+id/btn_0"> 
      ." android:id="@+id/btn_dot"> 
      +" android:id="@+id/btn_plus"> 
      =" android:id="@+id/btn_equal"> 
      
     
   

布局效果:

Android 使用 TableLayout 布局拉伸宽度_第1张图片

显然这不能满足我们的期望,下面我们演示 使用 android:stretchColumns 来自动拉伸

我们这里简单的给 TableLayout 增加一个属性 android:stretchColumns="*" 表示所有列都要自动拉伸,以便适应屏幕宽度。

布局效果

Android 使用 TableLayout 布局拉伸宽度_第2张图片

它的值即可以是数字,也可以是*,注意数字是从0开始的,即:android:stretchColumns="1" 是设置 TableLayout所有行的第二列为扩展列。

上面我们会看到 第四列的按钮比其他列的按钮要宽,如果我们想都一样宽如何办呢?

一个简单办法:

在自动拉伸的基础上,把每一列的宽度都设置成一样,比如下面的代码:


    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"> <TableLayout android:layout_width="match_parent" android:layout_height="match_parent" android:stretchColumns="*"> <TableRow> <EditText android:id="@+id/et_led" android:layout_width="fill_parent" android:digits="1234567890.+-*/=%/n/t()" android:text="" android:layout_span="4" />  TableRow> <TableRow> <Button android:text="(" android:id="@+id/btn_LeftParenthesis" android:layout_width="1dip"> Button> <Button android:text=")" android:id="@+id/btn_RightParenthesis" android:layout_width="1dip"> Button> <Button android:text="*" android:id="@+id/btn_x" android:layout_width="1dip"> Button> <Button android:text="back" android:id="@+id/btn_back" android:layout_width="1dip"> Button>  TableRow> <TableRow> <Button android:text="7" android:id="@+id/btn_7"> Button> <Button android:text="8" android:id="@+id/btn_8"> Button> <Button android:text="9" android:id="@+id/btn_9"> Button> <Button android:text="%" android:id="@+id/btn_mod"> Button>  TableRow> <TableRow> <Button android:text="4" android:id="@+id/btn_4"> Button> <Button android:text="5" android:id="@+id/btn_5"> Button> <Button android:text="6" android:id="@+id/btn_6"> Button> <Button android:text="/" android:id="@+id/btn_div"> Button>  TableRow> <TableRow> <Button android:text="1" android:id="@+id/btn_1"> Button> <Button android:text="2" android:id="@+id/btn_2"> Button> <Button android:text="3" android:id="@+id/btn_3"> Button> <Button android:text="-" android:id="@+id/btn_sub"> Button>  TableRow> <TableRow> <Button android:text="0" android:id="@+id/btn_0"> Button> <Button android:text="." android:id="@+id/btn_dot"> Button> <Button android:text="+" android:id="@+id/btn_plus"> Button> <Button android:text="=" android:id="@+id/btn_equal"> Button>  TableRow>  TableLayout>  LinearLayout>

这时候的效果就成了:

注意比起最初的就多了2个设置

android:layout_width="1dip" 和  android:stretchColumns="*"

Android 使用 TableLayout 布局拉伸宽度_第3张图片

你可能感兴趣的:(android,layout,扩展,div,button,encoding)