Docsity
Docsity

Prepara tus exámenes
Prepara tus exámenes

Prepara tus exámenes y mejora tus resultados gracias a la gran cantidad de recursos disponibles en Docsity


Consigue puntos base para descargar
Consigue puntos base para descargar

Gana puntos ayudando a otros estudiantes o consíguelos activando un Plan Premium


Orientación Universidad
Orientación Universidad


Introducción a Layouts en Android: LinearLayout, TableLayout, GridLayout y RelativeLayout, Apuntes de Programación Java

Introduccion Android Studio programacion móvil multiplataforma

Tipo: Apuntes

2019/2020

Subido el 30/03/2020

simonrusu
simonrusu 🇪🇸

4 documentos

1 / 11

Toggle sidebar

Esta página no es visible en la vista previa

¡No te pierdas las partes importantes!

bg1
Interfaz de usuario en Android:
Layouts
En el tema anterior, ya hicimos algunos comentarios sobre los layouts.
Como ya indicamos, los layouts son elementos no visuales destinados
a controlar la distribución, posición y dimensiones de los controles que
se insertan en su interior. Estos componentes extienden a la clase
base ViewGroup, como muchos otros componentes contenedores, es
decir, capaces de contener a otros controles. En el tema anterior
conocimos la existencia de un tipo concreto de layout,
LinearLayout, aunque Android nos proporciona algunos otros.
Veamos cuántos y cuáles.
FrameLayout
Éste es el más simple de todos los layouts de Android. Un
FrameLayout coloca todos sus controles hijos alineados con su
esquina superior izquierda, de forma que cada control quedará oculto
por el control siguiente (a menos que éste último tenga transparencia).
Por ello, suele utilizarse para mostrar un único control en su interior, a
modo de contenedor (placeholder) sencillo para un sólo elemento
sustituible, por ejemplo una imagen.
Los componentes incluidos en un FrameLayout deberán establecer
sus propiedades android:layout_width y
android:layout_height, que podrán tomar los valores
match_parent” (para que el control hijo tome la dimensión de su
layout contenedor) o “wrap_content” (para que el control hijo tome
la dimensión de su contenido). Veamos un ejemplo:
pf3
pf4
pf5
pf8
pf9
pfa

Vista previa parcial del texto

¡Descarga Introducción a Layouts en Android: LinearLayout, TableLayout, GridLayout y RelativeLayout y más Apuntes en PDF de Programación Java solo en Docsity!

Interfaz de usuario en Android:

Layouts

En el tema anterior, ya hicimos algunos comentarios sobre los layouts. Como ya indicamos, los layouts son elementos no visuales destinados a controlar la distribución, posición y dimensiones de los controles que se insertan en su interior. Estos componentes extienden a la clase base ViewGroup, como muchos otros componentes contenedores, es decir, capaces de contener a otros controles. En el tema anterior conocimos la existencia de un tipo concreto de layout, LinearLayout, aunque Android nos proporciona algunos otros. Veamos cuántos y cuáles. FrameLayout Éste es el más simple de todos los layouts de Android. Un FrameLayout coloca todos sus controles hijos alineados con su esquina superior izquierda, de forma que cada control quedará oculto por el control siguiente (a menos que éste último tenga transparencia). Por ello, suele utilizarse para mostrar un único control en su interior, a modo de contenedor ( placeholder ) sencillo para un sólo elemento sustituible, por ejemplo una imagen. Los componentes incluidos en un FrameLayout deberán establecer sus propiedades android:layout_width y android:layout_height, que podrán tomar los valores “match_parent” (para que el control hijo tome la dimensión de su layout contenedor) o “wrap_content” (para que el control hijo tome la dimensión de su contenido). Veamos un ejemplo:

1 2 3 4 5 6 7 8 9 10 11 Con el código anterior conseguimos un layout tan sencillo como el siguiente: LinearLayout El siguiente tipo de layout en cuanto a nivel de complejidad es el LinearLayout. Este layout apila uno tras otro todos sus elementos hijos en sentido horizontal o vertical según se establezca su propiedad android:orientation. Al igual que en un FrameLayout, los elementos contenidos en un LinearLayout pueden establecer sus propiedades android:layout_width y android:layout_height para determinar sus dimensiones dentro del layout. 1 2 3 4 5

21 22 23 24 25 26 27 28 29 30 31 32 android:layout_width="match_parent" android:layout_height="wrap_content " android:inputType="text" android:layout_weight="1" /> Con el código anterior conseguiríamos añadir un layout como el siguiente: Así pues, a pesar de la simplicidad aparente de este layout resulta ser lo suficiente versátil como para sernos de utilidad en muchas ocasiones. TableLayout Un TableLayout permite distribuir sus elementos hijos de forma tabular, definiendo las filas y columnas necesarias, y la posición de cada componente dentro de la tabla.

La estructura de la tabla se define de forma similar a como se hace en HTML, es decir, indicando las filas que compondrán la tabla (objetos TableRow), y dentro de cada fila las columnas necesarias, con la salvedad de que no existe ningún objeto especial para definir una columna (algo así como un TableColumn ) sino que directamente insertaremos los controles necesarios dentro del TableRow y cada componente insertado (que puede ser un control sencillo o incluso otro ViewGroup) corresponderá a una columna de la tabla. De esta forma, el número final de filas de la tabla se corresponderá con el número de elementos TableRow insertados, y el número total de columnas quedará determinado por el número de componentes de la fila que más componentes contenga. Por norma general, el ancho de cada columna se corresponderá con el ancho del mayor componente de dicha columna, pero existe una serie de propiedades que nos ayudarán a modificar este comportamiento:  android:stretchColumns. Indicará las columnas que pueden expandir para absorber el espacio libre dejado por las demás columnas a la derecha de la pantalla.  android:shrinkColumns. Indicará las columnas que se pueden contraer para dejar espacio al resto de columnas que se puedan salir por la derecha de la pantalla.  android:collapseColumns. Indicará las columnas de la tabla que se quieren ocultar completamente. Todas estas propiedades del TableLayout pueden recibir una lista de índices de columnas separados por comas (ejemplo: android:stretchColumns=”1,2,3″) o un asterisco para indicar que debe aplicar a todas las columnas (ejemplo: android:stretchColumns=”*”).

GridLayout Este tipo de layout fue incluido a partir de la API 14 (Android 4.0) y sus características son similares al TableLayout, ya que se utiliza igualmente para distribuir los diferentes elementos de la interfaz de forma tabular, distribuidos en filas y columnas. La diferencia entre ellos estriba en la forma que tiene el GridLayout de colocar y distribuir sus elementos hijos en el espacio disponible. En este caso, a diferencia del TableLayout indicaremos el número de filas y columnas como propiedades del layout, mediante android:rowCount y android:columnCount. Con estos datos ya no es necesario ningún tipo de elemento para indicar las filas, como hacíamos con el elemento TableRow del TableLayout, sino que los diferentes elementos hijos se irán colocando ordenadamente por filas o columnas (dependiendo de la propiedad android:orientation) hasta completar el número de filas o columnas indicadas en los atributos anteriores. Adicionalmente, igual que en el caso anterior, también tendremos disponibles las propiedades android:layout_rowSpan y android:layout_columnSpan para conseguir que una celda ocupe el lugar de varias filas o columnas.

Existe también una forma de indicar de forma explícita la fila y columna que debe ocupar un determinado elemento hijo contenido en el GridLayout, y se consigue utilizando los atributos android:layout_row y android:layout_column. De cualquier forma, salvo para configuraciones complejas del grid no suele ser necesario utilizar estas propiedades. Con todo esto en cuenta, para conseguir una distribución equivalente a la del ejemplo anterior del TableLayout, necesitaríamos escribir un código como el siguiente: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 RelativeLayout El último tipo de layout que vamos a ver es el RelativeLayout. Este layout permite especificar la posición de cada elemento de forma relativa a su elemento padre o a cualquier otro elemento incluido en el propio layout. De esta forma, al incluir un nuevo elemento X podremos indicar por ejemplo que debe colocarse debajo del elemento Y y alineado a la derecha del layout padre. Veamos esto en el ejemplo siguiente:

 android:layout_toRightOf  android:layout_alignLeft  android:layout_alignRight  android:layout_alignTop  android:layout_alignBottom  android:layout_alignBaseline Posición relativa al layout padre:  android:layout_alignParentLeft  android:layout_alignParentRight  android:layout_alignParentTop  android:layout_alignParentBottom  android:layout_centerHorizontal  android:layout_centerVertical  android:layout_centerInParent Por último indicar que cualquiera de los tipos de layout anteriores poseen otras propiedades comunes como por ejemplo los márgenes exteriores ( margin ) e interiores ( padding ) que pueden establecerse mediante los siguientes atributos: Opciones de margen exterior:  android:layout_margin  android:layout_marginBottom  android:layout_marginTop  android:layout_marginLeft  android:layout_marginRight Opciones de margen interior:  android:padding  android:paddingBottom

 android:paddingTop  android:paddingLeft  android:paddingRight Existen otros layouts algo más sofisticados a los que dedicaremos artículos específicos un poco más adelante, como por ejemplo el DrawerLayout para añadir menús laterales deslizantes. También en próximos temas veremos otros elementos comunes que extienden a ViewGroup, como por ejemplo las vistas de tipo lista (ListView), de tipo grid (GridView), y las pestañas o tabs (TabHost/TabWidget).