it-swarm-es.com

¿Cómo hacer el diseño con Ver llenar el espacio restante?

Estoy diseñando mi aplicación UI. Necesito un diseño como este:

Example of desired layout

(<y> son botones). El problema es que no sé cómo asegurarse de que TextView ocupará el espacio restante, ya que dos botones tienen un tamaño fijo.

Si uso fill_parent para la Vista de texto, el segundo botón (>) no se puede mostrar.

¿Cómo puedo diseñar un diseño que se parezca a la imagen?

170
Luke Vo

La respuesta de woodshy funcionó para mí, y es más simple que la respuesta de Ungureanu Liviu ya que no usa RelativeLayout. Estoy dando mi diseño para mayor claridad:

<LinearLayout 
      Android:layout_width="fill_parent"
      Android:layout_height="wrap_content"
      Android:orientation="horizontal"
      >

     <Button
        Android:layout_width = "80dp"
        Android:layout_weight = "0"
        Android:layout_height = "wrap_content"
        Android:text="&lt;"/>
     <TextView
        Android:layout_width = "fill_parent"
        Android:layout_height = "wrap_content"
        Android:layout_weight = "1"/>
     <Button
        Android:layout_width = "80dp"
        Android:layout_weight = "0"
        Android:layout_height = "wrap_content"
        Android:text="&gt;"/>   
 </LinearLayout>
185
Vivek Pandey

En caso de que <TEXT VIEW> se coloque en LinearLayout, establezca la propiedad Layout_weight de <y> en 0 y 1 para TextView.
En el caso de RelativeLayout, alinea <y> a la izquierda y a la derecha y configura "Diseño a la izquierda de" y "Diseño a la derecha de" propiedad de TextView a los identificadores de <y>

92
woodshy

Si usas RelativeLayout, puedes hacerlo de la siguiente manera:

<RelativeLayout
    Android:layout_width = "fill_parent"
    Android:layout_height = "fill_parent">
    <ImageView
        Android:id = "@+id/my_image"
        Android:layout_width = "wrap_content"
        Android:layout_height = "wrap_content"
        Android:layout_alignParentTop ="true" />
    <RelativeLayout
        Android:id="@+id/layout_bottom"
        Android:layout_width="fill_parent"
        Android:layout_height = "50dp"
        Android:layout_alignParentBottom = "true">
        <Button
            Android:id = "@+id/but_left"
            Android:layout_width = "80dp"
            Android:layout_height = "wrap_content"
            Android:text="&lt;"
            Android:layout_alignParentLeft = "true"/>
        <TextView
            Android:layout_width = "fill_parent"
            Android:layout_height = "wrap_content"
            Android:layout_toLeftOf = "@+id/but_right"
            Android:layout_toRightOf = "@id/but_left" />
        <Button
            Android:id = "@id/but_right"
            Android:layout_width = "80dp"
            Android:layout_height = "wrap_content"
            Android:text="&gt;"
            Android:layout_alignParentRight = "true"/>
    </RelativeLayout>
</RelativeLayout>
71
Ungureanu Liviu

Usando una ConstraintLayout, he encontrado algo como

<Button
    Android:id="@+id/left_button"
    Android:layout_width="80dp"
    Android:layout_height="48dp"
    Android:text="&lt;"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintTop_toTopOf="parent" />

<TextView
    Android:layout_width="0dp"
    Android:layout_height="0dp"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintLeft_toRightOf="@+id/left_button"
    app:layout_constraintRight_toLeftOf="@+id/right_button"
    app:layout_constraintTop_toTopOf="parent" />

<Button
    Android:id="@+id/right_button"
    Android:layout_width="80dp"
    Android:layout_height="48dp"
    Android:text="&gt;"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintRight_toRightOf="parent"
    app:layout_constraintTop_toTopOf="parent" />

trabajos. La clave es configurar adecuadamente las restricciones de borde derecho, izquierdo, superior e inferior, luego establecer el ancho y la altura en 0dp y dejar que calcule su propio tamaño.

25
Tom Howard

Es simple. Usted establece el minWidth o minHeight, depende de lo que está buscando, horizontal o vertical. Y para el otro objeto (el que desea que ocupe el espacio restante), establece un peso de 1 (establezca el ancho para envolver su contenido), de modo que llenará el resto del área.

<LinearLayout
        Android:layout_width="wrap_content"
        Android:layout_height="match_parent"
        Android:layout_weight="1"
        Android:gravity="center|left"
        Android:orientation="vertical" >
</LinearLayout>
<LinearLayout
        Android:layout_width="80dp"
        Android:layout_height="fill_parent"
        Android:minWidth="80dp" >
</LinearLayout>
7
Daniel

puedes usar el atributo layout_weight alto. A continuación puede ver un diseño donde ListView ocupa todo el espacio libre con botones en la parte inferior:

<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:tools="http://schemas.Android.com/tools"
    Android:layout_width="fill_parent"
    Android:layout_height="fill_parent"
    tools:context=".ConfigurationActivity"
    Android:orientation="vertical"
    >

        <ListView
            Android:id="@+id/listView"
            Android:layout_width="fill_parent"
            Android:layout_height="fill_parent"
            Android:layout_weight="1000"
            />


        <Button
            Android:id="@+id/btnCreateNewRule"
            Android:layout_width="fill_parent"
            Android:layout_height="wrap_content"
            Android:layout_weight="1"
            Android:text="Create New Rule" />



        <Button
            Android:id="@+id/btnConfigureOk"
            Android:layout_width="fill_parent"
            Android:layout_height="wrap_content"
            Android:layout_weight="1"
            Android:text="Ok" />


</LinearLayout>
4
thinker

Para aquellos que tienen la misma falla con <LinearLayout...> que yo:

Es importante especificar Android:layout_width="fill_parent", no funcionará con wrap_content.

OTOH, puede omitir Android:layout_weight = "0", no es obligatorio.

Mi código es básicamente el mismo que el de https://stackoverflow.com/a/25781167/755804 (por Vivek Pandey)

3

Debe evitar anidar el diseño relativo 2 ya que el diseño relativo siempre hace 2 pasadas para el dibujo (contra 1 para cualquier otro tipo de diseño). Se vuelve exponencial cuando los anidas. Debe usar un diseño lineal con ancho = 0 y peso = 1 en el elemento que desea llenar el espacio que queda. Esta respuesta es mejor para el rendimiento y las prácticas. Recuerde: use el diseño relativo SOLO cuando no tenga otra opción.

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
          Android:layout_width="match_parent"
          Android:layout_height="match_parent"
          Android:orientation="vertical">

    <ImageView
        Android:id="@+id/imageview"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content" />

    <LinearLayout
        Android:layout_width="match_parent"
        Android:layout_height="50dp"
        Android:orientation="horizontal">

        <Button
            Android:id="@+id/prev_button"
            Android:layout_width="80dp"
            Android:layout_height="wrap_content"
            Android:text="&lt;" />

        <TextView
            Android:layout_width="0dp"
            Android:layout_height="wrap_content"
            Android:layout_weight="1"
            Android:ellipsize="end"
            Android:singleLine="true"
            Android:gravity="center"
            Android:text="TextView" />

        <Button
            Android:id="@+id/next_button"
            Android:layout_width="80dp"
            Android:layout_height="wrap_content"
            Android:text="&gt;" />
    </LinearLayout>
</LinearLayout>
2
Livio

Puede usar establecer layout_width o layout_width a 0dp (por la orientación que desee llenar el espacio restante). Luego use layout_weight para hacer que llene el espacio restante.

0
taynguyen

use un Relativelayout para ajustar LinearLayout

<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
xmlns:round="http://schemas.Android.com/apk/res-auto"
xmlns:app="http://schemas.Android.com/apk/res-auto"
Android:layout_width="match_parent"
Android:layout_height="match_parent">
<LinearLayout
Android:layout_width="fill_parent"
Android:layout_height="match_parent"
Android:orientation="vertical">
    <Button
        Android:layout_width = "wrap_content"
        Android:layout_height = "wrap_content"
        Android:text="&lt;"/>
    <TextView
        Android:layout_width = "fill_parent"
        Android:layout_height = "wrap_content"
        Android:layout_weight = "1"/>
    <Button
        Android:layout_width = "wrap_content"
        Android:layout_height = "wrap_content"
        Android:text="&gt;"/>

</LinearLayout>

</RelativeLayout>`
0
john liao

encontré

 <TextView
        Android:layout_width="wrap_content"
        Android:layout_height="match_parent"
        Android:layout_marginEnd="10dp"
        Android:fontFamily="casual"
        Android:text="(By Zeus B0t)"
     ``   Android:textSize="10sp"
        Android:gravity="bottom"
        Android:textStyle="italic" />
0
Zeus B0t