¿Cómo puedo lograr el siguiente diseño, con TextView siendo TextView
con elipsis y Vista siendo wrap_content
e inmediatamente a la derecha de TextView?Android - Elipsis con vista alineada a la derecha
Aquí hay tres ejemplos de cómo el diseño debe comportarse, con diferente anchura TextView:
|[TextView] [View] |
|[TextView TextView] [View] |
|[TextView TextView T...] [View]|
[Editar]
La siguiente TableLayout
da el comportamiento correcto:
<TableLayout
android:id="@+id/upper_layout"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_toLeftOf="@+id/alert_button"
android:shrinkColumns="0"
android:stretchColumns="2" >
<TableRow>
<TextView
android:id="@+id/name_textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:ellipsize="end"
android:includeFontPadding="false"
android:lines="1"
android:paddingTop="2dp"
android:scrollHorizontally="true" />
<TextView
android:id="@+id/unread_count_textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:gravity="center"
android:includeFontPadding="false"
android:paddingBottom="0dp"
android:paddingLeft="5dp"
android:paddingRight="5dp"
android:paddingTop="2dp" />
</TableRow>
</TableLayout>
Los TableLayout
utiliza 3 columnas, siendo la última el truco: la propiedad strechColumns
hace que ocupe todo el espacio disponible, por lo que el segundo TextView
siempre está inmediatamente a la derecha del primero. La primera elipse TextView
correctamente debido a la propiedad shrinkColumns
.
Sin embargo, no me gusta la idea de usar un TableLayout
para lograr eso. ¿Alguien sabe una mejor manera?
Gracias
¿Es esta una lista o no? – Yury
Sí, es un diseño de fila. – gdelente