Utilizzando TextView
all'interno GridLayout
è problematica, ma non v'è un buon modo per utilizzare entrambi insieme.
Questo è ciò che il layout di esempio si presenta come:
E questo è il xml layout completo, le linee importanti sono contrassegnate con ***.
<?xml version="1.0" encoding="utf-8"?>
<GridLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:columnCount="3" * this example uses 3 columns
android:orientation="horizontal" > *** use "horizontal"
<TextView * just a normal view
android:layout_column="0"
android:layout_row="0"
android:background="#666666"
android:text="A"
android:textColor="#afafaf"
android:textSize="60sp"
android:textStyle="bold" />
<TextView * this text will not be cut!
android:layout_width="0dp" *** important: set width to 0dp
android:layout_height="wrap_content"
android:layout_column="1"
android:layout_columnSpan="2" * colspan does also work with this
android:layout_gravity="fill_horizontal|bottom" *** set to "fill*"!
android:layout_row="0"
android:text="This view has 2 columns. Lorem ipsum dolor sit amet, consetetur sadipscing elitr."
android:textColor="#666666" />
</GridLayout>
A seconda delle esigenze, anche questa combinazione funziona:
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_gravity="fill"
android:gravity="bottom"
Si noti che non c'è bisogno di utilizzare qualsiasi spazio dei nomi diverso android
per questo lavoro.
È importante notare l'app **: layout_gravity. Stavo impostando il valore in uno stile e non mi aveva avvertito, mi ci è voluto un po 'per capire il problema. – basilisk
Prende la larghezza della larghezza della riga precedente se si trova nella seconda riga –