Aprende a crear diseños horizontales con javafx.scene.layout.HBox en JavaFX

| Última modificación: 14 de enero de 2025 | Tiempo de Lectura: 4 minutos

Algunos de nuestros reconocimientos:

Premios KeepCoding

Me acuerdo que en cierta ocasión diseñé una barra de navegación en JavaFX y mi error fue que alineé los botones de forma manual, entonces los usuarios empezaron a quejarse diciendo que era muy complicado encontrar las opciones. Me dio mucha pena y vergüenza, pero pude corregirlo con javafx.scene.layout.HBox, una herramienta que me permitió transformar la experiencia del usuario al ofrecerles una navegación más intuitiva. Ahí fue que todo empezó a funcionar mejor. Por eso voy a explicarte cómo puedes crear diseños horizontales con este contenedor y darle lo mejor de lo mejor a tus usuarios.

javafx.scene.layout.HBox qué es

¿Qué es javafx.scene.layout.HBox?

Piensa en una línea horizontal, donde tú quieres organizar una fila de elementos, como botones, etiquetas o imágenes, uno al lado del otro. Esa línea sería el javafx.scene.layout.HBox. Resulta que es como una caja horizontal en la que puedes colocar estos elementos para crear diseños horizontales o que tengan esa disposición.

Entonces, el HBox u horizontal box es la representación de un contenedor horizontal en JavaFX que te sirve para organizar los elementos de tu interfaz de usuario en una fila.

Características:

  • Es un contenedor: Así como VBox, por eso puedes agregar otros elementos (nodos) dentro de él.
  • Orientación horizontal: Los elementos que añadas a un HBox se colocarán uno al lado del otro, formando una fila.
  • Espaciado: Puedes definir el espacio entre cada elemento para controlar la separación entre ellos.
  • Alineación: Puedes controlar la alineación de los elementos dentro del HBox (por ejemplo, en la parte superior, en el centro o en la parte inferior).

¿Cómo usar javafx.scene.layout.HBox?

Aprende a crear un HBox

Crear un HBox es realmente fácil. Puedes usar el constructor vacío o inicializarlo con una lista de nodos.

Ejemplo básico

HBox hbox = new HBox(); // Crea un HBox vacío

Ejemplo con nodos iniciales

Button btn1 = new Button("Botón 1");
Button btn2 = new Button("Botón 2");

HBox hbox = new HBox(10, btn1, btn2); // Espaciado de 10 píxeles entre nodos

Aquí, he creado un HBox con dos botones separados por 10 píxeles.

Añade un HBox al gráfico de escena

Para que un HBox se pueda ver, debes añadirlo al gráfico de escena con Scene y Stage.

Ejemplo práctico

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.layout.HBox;
import javafx.stage.Stage;

public class HBoxExample extends Application {
@Override
public void start(Stage primaryStage) {
Button btn1 = new Button("Inicio");
Button btn2 = new Button("Ayuda");
Button btn3 = new Button("Salir");

HBox hbox = new HBox(15, btn1, btn2, btn3); // Espaciado entre nodos

Scene scene = new Scene(hbox, 400, 100);
primaryStage.setScene(scene);
primaryStage.setTitle("Ejemplo de HBox");
primaryStage.show();
}

public static void main(String[] args) {
launch(args);
}
}

Como ves, este código crea una fila con tres botones separados por 15 píxeles.

Cómo personalizar javafx.scene.layout.HBox

Espaciado entre nodos

Observa cómo puedes ajustar el espacio entre nodos de dos formas:

  • Una es en el constructor del HBox.
  • La otra es usando el método setSpacing().
hbox.setSpacing(20); // Espaciado de 20 píxeles

Márgenes de los nodos

Configura márgenes específicos para cada nodo con el método setMargin().

HBox.setMargin(btn1, new Insets(10, 20, 10, 20)); // Márgenes: arriba, derecha, abajo, izquierda

Alineación de los nodos

El método setAlignment() te deja controlar cómo se distribuyen los nodos dentro del HBox.

hbox.setAlignment(Pos.CENTER); // Alineación central

Estas son las opciones comunes de alineación:

  • Pos.TOP_LEFT: Arriba a la izquierda.
  • Pos.CENTER: Centrado.
  • Pos.BOTTOM_RIGHT: Abajo a la derecha.

Expansión horizontal de los nodos

Para que un nodo dentro del HBox ocupe todo el ancho disponible, usa el método setHgrow().

HBox.setHgrow(btn1, Priority.ALWAYS);

Esto permite que el botón se expanda horizontalmente para llenar el espacio restante.

Ejemplo avanzado: barra de navegación

Aquí te muestro cómo usar un HBox para crear una barra de navegación horizontal con tres botones y que no te pase lo mismo que a mí.

import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.layout.HBox;
import javafx.stage.Stage;

public class NavigationBarExample extends Application {
@Override
public void start(Stage primaryStage) {
Button homeButton = new Button("Inicio");
Button aboutButton = new Button("Acerca de");
Button contactButton = new Button("Contacto");

HBox hbox = new HBox(10, homeButton, aboutButton, contactButton);
hbox.setAlignment(Pos.CENTER); // Centrar los botones

Scene scene = new Scene(hbox, 600, 80);
primaryStage.setScene(scene);
primaryStage.setTitle("Barra de Navegación con HBox");
primaryStage.show();
}

public static void main(String[] args) {
launch(args);
}
}

Estilizando HBox con CSS

Recuerda que también puedes aplicar estilos CSS para personalizar la apariencia de tu HBox.

hbox.setStyle("-fx-background-color: #e0e0e0; -fx-padding: 10; -fx-border-color: black; -fx-border-width: 1;");

Mira las propiedades comunes para HBox:

  • -fx-padding: Espaciado interno del contenedor.
  • -fx-border-color: Color del borde.
  • -fx-background-color: Color de fondo.

Lo cierto es que javafx.scene.layout.HBox es excelente para organizar elementos en un diseño horizontal en JavaFX. Me gustan sus opciones de personalización y que es fácil de usar. Además, puedes crear diseños efectivos y visualmente atractivos para tus aplicaciones.

Apúntate al Bootcamp de Java Full Stack de KeepCoding y domina todas las herramientas para crear aplicaciones robustas y dinámicas. Desde lo básico hasta lo avanzado, te ayudamos a convertirte en un experto en Java. ¡Es tu momento de brillar en el sector IT!

Ramón Maldonado

Full Stack Developer y Responsable de Formación base en KeepCoding.

Posts más leídos