Android TableLayout Tutorial with Examples
1. Android TableLayout
TableLayout arranges the View(s) in table format. Specifically, TableLayout is a ViewGroup containing one or more TableRow(s). Each TableRow is a row in the table containing cells. Child View(s) can be placed in one cell or in a merged cell from adjacent cells of a row. Unlike tables in HTML, you cannot merge consecutive cells in the one column.
data:image/s3,"s3://crabby-images/008c1/008c1e3437b8bb219fb3d457dcb992a07e7819ce" alt=""
data:image/s3,"s3://crabby-images/15a17/15a17db6cc8c6485fa547b7a1ad26885e9c122b3" alt=""
TableLayout is similar to a regular View, which you can drag and drop it into an available interface:
data:image/s3,"s3://crabby-images/c7b0c/c7b0c83cb2def72aeab1d9cc6de3b3dff4c304e9" alt=""
Or use it as an original Layout of the interface:
data:image/s3,"s3://crabby-images/f4d70/f4d7029cc41df4092b4502268319f546dfb0f247" alt=""
Add TableRow(s)and View(s)to the TableLayout:
data:image/s3,"s3://crabby-images/bfd4f/bfd4f864e1a38d4c158541af3a080d27e8ecc9ad" alt=""
2. TableLayout - android:stretchColumns
In TableLayout the columns are indexed 0, 1, 2 ... The android:stretchColumns attribute allows you to specify which columns will be stretched to fill the free horizontal space of the TableLayout.
data:image/s3,"s3://crabby-images/82f06/82f06db0cf8a719105959a50e90dde712a589c53" alt=""
<!-- The columns with indexes 0 and 2 will be stretched. -->
<TableLayout
...
android:stretchColumns="0, 2">
...
</TableLayout>
<!-- All columns will be stretched. -->
<TableLayout
...
android:stretchColumns="*">
...
</TableLayout>
data:image/s3,"s3://crabby-images/ee907/ee90723b7105395cd5e774c0b8d1e0c935821140" alt=""
3. TableLayout - android:shrinkColumns
In contrast to android:stretchColumns, the android:shrinkColumns attribute specifies columns that will be shrinked to prevent child View(s) from spilling out of TableLayout.
data:image/s3,"s3://crabby-images/5dcb0/5dcb0dbb084e955ec633625b09f27df643f2dca1" alt=""
<!-- The columns with indexes 0 and 2 will be shrinked. -->
<TableLayout
...
android:shrinkColumns="0, 2">
...
</TableLayout>
<!-- All columns will be shrinked. -->
<TableLayout
...
android:shrinkColumns="*">
...
</TableLayout>
data:image/s3,"s3://crabby-images/8366d/8366d8949d9d13405e99c5fb3d0952fe8fb48e42" alt=""
4. TableLayout - android:collapseColumns
The android:collapseColumns attribute specifies columns that will be collapsed, meaning that the width of the column will be 0, and as a result, that column will be hidden.
<!-- The columns with indexes 0 and 2 will be collapsed-->
<TableLayout
...
android:collapseColumns="0, 2">
...
</TableLayout>
<!-- All columns will be collapsed---->
<TableLayout
...
android:collapseColumns="*">
...
</TableLayout>
data:image/s3,"s3://crabby-images/30ecb/30ecb6923472e932951bfc6a743f09d32e8bfd4a" alt=""
5. View - android:layout_column
The android:layout_column attribute is applied to a child View in a TableRow in orderto specify its column index. The values can probably be 0, 1, 2, ...
data:image/s3,"s3://crabby-images/5386d/5386de3bc460de326f329b596e9560e93bc47bfd" alt=""
6. View - android:layout_span
The android:layout_span attribute is applied to the child View(s) to specify the number of consecutive cells in a TableRow that will be merged together.
data:image/s3,"s3://crabby-images/5de39/5de392031d069e7a4862df993981a74fdb4484ab" alt=""
7. View - android:layout_gravity
The android:layout_gravity attribute is applied to child View(s) (of TableRow) to specify its relative position compared to the cell containing it. This attribute affects the behavior of the android:layout_width attribute.
Case 1: If the android:layout_gravity attribute is not set for the child View (of TableRow), the width of the child View will always fill the cell containing it, which means the android:layout_width attribute will always get the MATCH_PARENT value.
data:image/s3,"s3://crabby-images/d8179/d81795ef4bb5cf9ce36e4118cf6447e89dd0e888" alt=""
Case 2: If the android:layout_gravity attribute is set for the child View (of TableRow), the child View will always have the default width, which means the android:layout_width attribute will always get the WRAP_CONTENT value.
data:image/s3,"s3://crabby-images/ebd82/ebd82b4f064d15b0da536b137d0be163baf2176d" alt=""
The android:layout_gravity attribute is used to specify the location of the View in the cell containing it.
Constant in Java | Value | Description |
Gravity.LEFT | left | |
Gravity.CENTER_HORIZONTAL | center_horizontal | |
Gravity.RIGHT | right | |
Gravity.TOP | top | |
Gravity.CENTER_VERTICAL | center_vertical | |
Gravity.BOTTOM | bottom | |
Gravity.START | start | |
Gravity.END | end | |
Gravity.CENTER | center | |
8. View - android:layout_weight
The android:layout_weight attribute is used for child View(s) (of TableRow), which specifies how much space the child View takes up in the parent View (TableRow) horizontally. A layout_weight value greater than 0 allows the child View to expand in order to fill in the remaining space of the parent View. The child View can specify a layout_weight value; then all the remaining space in the parent View will be assigned to child View(s) according to their layout_weight ratio.
When all the child View(s) (of TableRow) have android:layout_weight = 0, you will see an empty space in the parent View (TableRow):
data:image/s3,"s3://crabby-images/04906/04906a228e402347850b24e5dfff2b846dd51339" alt=""
The child View(s) with android:layout_weight>0 will take up the free space of the parent View (TableRow):
data:image/s3,"s3://crabby-images/8f8aa/8f8aa4e07a5f1821e3f2e4f3c053f283304d4912" alt=""
The free space of the parent View (TableRow) will be allocated to the child View(s) according to their layout_weight ratio.
data:image/s3,"s3://crabby-images/ae98a/ae98ac07dc9e8ef02fa32a23990f305496cccc96" alt=""
9. Example of TableLayout
Have a look at the login window below. Do you think TableLayout can be usedto design its interface?
data:image/s3,"s3://crabby-images/c456b/c456b3c2e0b2576b95ead38484bd98e0a9bc1210" alt=""
The answer is "Absolutely yes", and here is a design idea draft:
data:image/s3,"s3://crabby-images/e602b/e602bb486697b2933401c2425749b1a099859023" alt=""
Next is to implement the idea:
Step 1: Add 5 TableRow(s) to the TableLayout:
data:image/s3,"s3://crabby-images/8dc6c/8dc6c3f401c300cd5b3e148d7a8347ced0e6dde2" alt=""
Step 2: Add 4 Button(s)to the first TableRow. We will have a four-column TableLayout which makes the design process easier. The first TableRow will be removed from the interface when the design process is complete.
data:image/s3,"s3://crabby-images/da4de/da4de7d952306b4021be50463d94fbb1fb8325af" alt=""
data:image/s3,"s3://crabby-images/67fa3/67fa3d75d2e178b52127f8d4cef90ff0063f08d1" alt=""
Step 3: Add other child View(s)to the interface:
data:image/s3,"s3://crabby-images/0cdb3/0cdb38260159de58a2536905c3ebcd162cc6ead2" alt=""
data:image/s3,"s3://crabby-images/3a322/3a32212c55a1fcfc8aa3aeef81180f603cc3e175" alt=""
Step 4: Set the android:layout_span attribute for some child View(s):
data:image/s3,"s3://crabby-images/e01c5/e01c51d0f1a4deba09aafd64bc572883558e966d" alt=""
Step 5: Set the android:layout_column for the "Login" button:
data:image/s3,"s3://crabby-images/e3190/e3190b7f62e8404d7a3086fc1e902cc55e9ab653" alt=""
Step 6: Stretch the columns with index 1 and 3:
- (TableLayout) android:stretchColumns = "1, 3"
data:image/s3,"s3://crabby-images/8b04a/8b04a84fd5291b921cac46813dd48e377002ef5d" alt=""
Step 7: Set the android:layout_gravity attribute for the "Login" and "Forget Password" buttons:
data:image/s3,"s3://crabby-images/a68e8/a68e863e5e0255b02836eb1ec80e513ff27e081e" alt=""
Bước 8: Set text, textSize, padding, and gravity for the child View(s) in the interface:
data:image/s3,"s3://crabby-images/f01c9/f01c9c42debc3c14835c33d24cb36a4ea329edef" alt=""
Step 9: Remove the first TableRow, and the interface design is done.
data:image/s3,"s3://crabby-images/551bb/551bb1dd42d54a06c4f616b8af5db6b690f0a81e" alt=""
layout_main.xml
<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="10dp"
android:stretchColumns="1, 3"
tools:context=".MainActivity">
<TableRow
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_span="4"
android:gravity="center"
android:text="Login"
android:textSize="22sp" />
</TableRow>
<TableRow
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingRight="10dp"
android:text="User name" />
<EditText
android:id="@+id/editText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_span="3"
android:ems="10"
android:inputType="textPersonName" />
</TableRow>
<TableRow
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/textView3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingRight="10dp"
android:text="Password" />
<EditText
android:id="@+id/editText2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_span="3"
android:ems="10"
android:inputType="textPassword" />
</TableRow>
<TableRow
android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:id="@+id/button5"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_column="1"
android:layout_gravity="right"
android:text="Login" />
<Button
android:id="@+id/button6"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Cancel" />
<Button
android:id="@+id/button7"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="left"
android:text="Forget Password?" />
</TableRow>
</TableLayout>
Android Programming Tutorials
- Configure Android Emulator in Android Studio
- Android ToggleButton Tutorial with Examples
- Create a simple File Finder Dialog in Android
- Android TimePickerDialog Tutorial with Examples
- Android DatePickerDialog Tutorial with Examples
- What is needed to get started with Android?
- Install Android Studio on Windows
- Install Intel® HAXM for Android Studio
- Android AsyncTask Tutorial with Examples
- Android AsyncTaskLoader Tutorial with Examples
- Android Tutorial for Beginners - Basic examples
- How to know the phone number of Android Emulator and change it
- Android TextInputLayout Tutorial with Examples
- Android CardView Tutorial with Examples
- Android ViewPager2 Tutorial with Examples
- Get Phone Number in Android using TelephonyManager
- Android Phone Call Tutorial with Examples
- Android Wifi Scanning Tutorial with Examples
- Android 2D Game Tutorial for Beginners
- Android DialogFragment Tutorial with Examples
- Android CharacterPickerDialog Tutorial with Examples
- Android Tutorial for Beginners - Hello Android
- Using Android Device File Explorer
- Enable USB Debugging on Android Device
- Android UI Layouts Tutorial with Examples
- Android SMS Tutorial with Examples
- Android SQLite Database Tutorial with Examples
- Google Maps Android API Tutorial with Examples
- Android Text to Speech Tutorial with Examples
- Android Space Tutorial with Examples
- Android Toast Tutorial with Examples
- Create a custom Android Toast
- Android SnackBar Tutorial with Examples
- Android TextView Tutorial with Examples
- Android TextClock Tutorial with Examples
- Android EditText Tutorial with Examples
- Android TextWatcher Tutorial with Examples
- Format Credit Card Number with Android TextWatcher
- Android Clipboard Tutorial with Examples
- Create a simple File Chooser in Android
- Android AutoCompleteTextView and MultiAutoCompleteTextView Tutorial with Examples
- Android ImageView Tutorial with Examples
- Android ImageSwitcher Tutorial with Examples
- Android ScrollView and HorizontalScrollView Tutorial with Examples
- Android WebView Tutorial with Examples
- Android SeekBar Tutorial with Examples
- Android Dialog Tutorial with Examples
- Android AlertDialog Tutorial with Examples
- Android RatingBar Tutorial with Examples
- Android ProgressBar Tutorial with Examples
- Android Spinner Tutorial with Examples
- Android Button Tutorial with Examples
- Android Switch Tutorial with Examples
- Android ImageButton Tutorial with Examples
- Android FloatingActionButton Tutorial with Examples
- Android CheckBox Tutorial with Examples
- Android RadioGroup and RadioButton Tutorial with Examples
- Android Chip and ChipGroup Tutorial with Examples
- Using image assets and icon assets of Android Studio
- Setting SD Card for Android Emulator
- ChipGroup and Chip Entry Example
- How to add external libraries to Android Project in Android Studio?
- How to disable the permissions already granted to the Android application?
- How to remove applications from Android Emulator?
- Android LinearLayout Tutorial with Examples
- Android TableLayout Tutorial with Examples
- Android FrameLayout Tutorial with Examples
- Android QuickContactBadge Tutorial with Examples
- Android StackView Tutorial with Examples
- Android Camera Tutorial with Examples
- Android MediaPlayer Tutorial with Examples
- Android VideoView Tutorial with Examples
- Playing Sound effects in Android with SoundPool
- Android Networking Tutorial with Examples
- Android JSON Parser Tutorial with Examples
- Android SharedPreferences Tutorial with Examples
- Android Internal Storage Tutorial with Examples
- Android External Storage Tutorial with Examples
- Android Intents Tutorial with Examples
- Example of an explicit Android Intent, calling another Intent
- Example of implicit Android Intent, open a URL, send an email
- Android Services Tutorial with Examples
- Android Notifications Tutorial with Examples
- Android DatePicker Tutorial with Examples
- Android TimePicker Tutorial with Examples
- Android Chronometer Tutorial with Examples
- Android OptionMenu Tutorial with Examples
- Android ContextMenu Tutorial with Examples
- Android PopupMenu Tutorial with Examples
- Android Fragments Tutorial with Examples
- Android ListView Tutorial with Examples
- Android ListView with Checkbox using ArrayAdapter
- Android GridView Tutorial with Examples
Show More