codestory

Die Anleitung zu Android TableLayout

  1. Android TableLayout
  2. TableLayout - android:stretchColumns
  3. TableLayout - android:shrinkColumns
  4. TableLayout - android:collapseColumns
  5. View - android:layout_column
  6. View - android:layout_span
  7. View - android:layout_gravity
  8. View - android:layout_weight
  9. Zum Beispiel TableLayout

1. Android TableLayout

TableLayout ordnet die View im Tabellenformat an. Insbesondere ist TableLayout ein ViewGroup , die eine oder mehrere TableRow enthält. Jede TableRow ist eine Zeile in der Tabelle, die Zellen enthält. Die untergeordnete View können in einer Zelle oder in einer zusammengeführten Zelle aus benachbarten Zellen einer Zeile platziert werden. Im Gegensatz zur Tabelle in HTML können Sie keine aufeinanderfolgenden Zellen in einer Spalte zusammenführen.
TableLayout ist so ähnlich wie ein normales View , Sie können in einer vorhandene Interface ziehen und ablegen:
Oder benutzen Sie es als das originelle Layout der Interface:
Fügen Sie die TableRow und View in TableLayout hinzu:

2. TableLayout - android:stretchColumns

In TableLayout sind die Spalten mit 0, 1, 2, usw indiziert. Mit dem Attribut android:stretchColumns können Sie angeben, welche Spalten gestreckt werden sollen, um den freien horizontalen Bereich vom TableLayout auszufüllen.
<!-- 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>

3. TableLayout - android:shrinkColumns

Im Gegensatz zu android:stretchColumns legt das Attribut android:shrinkColumns die Spalte fest, die verkleinert werden um zu verhindern, dass die untergeordnete View aus TableLayout verschüttet werden.
<!-- 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>

4. TableLayout - android:collapseColumns

Das Attribut android:collapseColumns legt die Spalten an, die reduziert werden sollen. Dies bedeutet, dass die Breite der Spalte 0 beträgt und diese Spalte daher ausgeblendet wird.
<!-- 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>

5. View - android:layout_column

Das Attribut android:layout_column wird für das untergeordnete View in einer TableRow um seine Spalte-Index anzugeben. Die Werte können 0, 1, 2,usw sein.

6. View - android:layout_span

Das Attribut android:layout_span wird für das untergeordnete View angewendet um die consekutiven Zelle in TableRow anzugeben, die verschmelzt miteinander werden.

7. View - android:layout_gravity

Das Attribut android:layout_gravity wird für die untergeordneten View (vom TableRow) angewendet um ihre relative Stelle im Verhältnis vom die Zelle,die sie enthält. Das Attribut wirkt die Behandlung vom Attribut android:layout_width aus.
Der Fall 1: Wenn das Attribut android:layout_gravity für das untergeordnete View (vom TableRow) angegeben wird, wird die Breite vom untergeordneten View die Zelle erfüllen, die sie enthält, das bedeutet, dass das Attribut android:layout_width den Wert MATCH_PARENT immer bekommen.
Der Fall 2: Wenn das Attribut android:layout_gravity für das untergeordnete View (vom TableRow) angegeben, wird das geordnete View die standardmäßige Breite immer haben, das bedeutet, dass das Attritbut android:layout_width den Wert WRAP_CONTENT immer erhalten.
Das Attribut android:layout_gravity wird angewendet um die Stelle von View in die Zelle anzugeben, die es enthält.
Constant in Java
Value
Description
Gravity.LEFT
left
Gravity.CENTER_HORIZONTAL
center_horizontal
Gravity.RIGHT
right
Gravity.CLIP_HORIZONTAL
clip_horizontal
Gravity.FILL_HORIZONTAL
fill_horizontal
Gravity.TOP
top
Gravity.CENTER_VERTICAL
center_vertical
Gravity.BOTTOM
bottom
Gravity.CLIP_VERTICAL
clip_vertical
Gravity.FILL_VERTICAL
fill_vertical
Gravity.START
start
Gravity.END
end
Gravity.CENTER
center
Gravity.FILL
fill

8. View - android:layout_weight

Das Attribut android:layout_weight wird für das untergeordnete View (von TableRow) verwendet, die angeben, wieviel Speicherplatz die untergeordnete View in dem übergeordnete View (TableRow) horizontal einnimmt. Ein Wert layout_weight größer als 0 ermöglicht das Erweitern der untergeordneten View , um den verbleibenden Platz in der übergeordneten View auszufüllen. Die untergeordnete View kann einen Wert layout_weight angeben. Anschließend wird der gesamte verbleibende Speicherplatz in der übergeordnete View den untergeordneten View entsprechend ihrem Verhältnis von layout_weight zugewiesen.
Wenn alle untergeordneten View (vom TableRow) android:layout_weight=0 haben, werden Sie einen leeren Platz in dem übergeordneten View (TableRow):
Die untergeordneten View mit android:layout_weight>0 werden den leeren Platz vom übergeordneten View (TableRow) einnehmen:
Der leeren Platz vom übergeordneten View (TableRow) wird für die untergeordneten View im Verhältnis vom layout_weight lokalisiert werden.

9. Zum Beispiel TableLayout

Unter ist das ein Anmeldungsfenster. Denken Sie daran,dass TableLayout benutzt wird, seine Interface zu entwerfen?
Die Anwort "absolut ja", und hier ist das Entwurf zur Design-Idee:
Zunäscht ist es die Ausführung der Idee:
Schritt 1: Fügen Sie 5 TableRow in TableLayout hinzu:
Schritt 2: Fügen Sie 4 Button in den ersten TableRow hinzu. Wir werden ein TableLayout mit 4 Spalte haben. Dies macht den Design-Prozess leichter. Der erste TableRow wird nach der erfolgreichen Designprozess aus der Interface gelöscht.
Schritt 3: Fügen Sie die anderen untergeordneten View in die Interface hinzu:
Schritt 4: Legen Sie das Attribut android:layout_span für einige untergeordneten View fest:
Schritt 5: Legen Sie android:layout_column für Button "Login" fest:
Schritt 6: Dehnen Sie die Spalten mit Index 1 und 3:
  • (TableLayout) android:stretchColumns = "1, 3"
Schritt 7: Legen Sie das Attribut android:layout_gravity für Button "Login" und "Forget Password" fest:
Schritt 8: Legen Sie text, textSize, padding, gravity für die untergeordneten View in die Interface fest:
Schritt 9: Löschen Sie den ersten TableRow und das Interface-Design ist fertig.
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>

Anleitungen Android

Show More