轉自:http://www.cnblogs.com/ghj1976/archive/2011/04/21/2023850.html
佈局檔案
<?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"> <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"></Button> <Button android:text=")" android:id="@+id/btn_RightParenthesis"></Button> <Button android:text="*" android:id="@+id/btn_x"></Button> <Button android:text="back" android:id="@+id/btn_back"></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>
佈局效果:
顯然這不能滿足我們的期望,下面我們演示 使用 android:stretchColumns 來自動拉伸
我們這裡簡單的給 TableLayout 增加一個屬性 android:stretchColumns="*" 表示所有列都要自動拉伸,以便適應螢幕寬度。
佈局效果
它的值即可以是數字,也可以是*,注意數字是從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="*"