Slider
El componente Slider ofrece a los usuarios una manera de seleccionar un valor numérico arrastrando un botón a lo largo de una pista entre un límite mínimo y máximo. Los intervalos de pasos, las marcas de ticks y las etiquetas se pueden configurar para guiar la selección.
Básicos
El Slider está diseñado para funcionar directamente, requiriendo ninguna configuración adicional para ser efectivo. Por defecto, abarca un rango de 0 a 100 con un valor inicial de 50, lo que lo hace ideal para una rápida integración en cualquier aplicación. Para casos de uso más específicos, el Slider se puede personalizar con propiedades como orientación, marcas de ticks, etiquetas y tooltips.
Aquí hay un ejemplo de un Slider que permite a los usuarios ajustar los niveles de volumen dentro de un rango predefinido:
Mostrar Código
- SliderView.java
Valor del Slider
El valor del Slider representa la posición actual del botón en el deslizador y se define como un entero dentro del rango del Slider. Este valor se actualiza dinámicamente a medida que el usuario interactúa con el deslizador, convirtiéndose en una propiedad esencial para rastrear la entrada del usuario.
Por defecto, el Slider comienza con un valor de 50, asumiendo el rango predeterminado de 0 a 100.
Establecer y obtener el valor
Puedes establecer el valor del Slider durante la inicialización o actualizarlo más tarde usando el método setValue(). Para recuperar el valor actual, utiliza el método getValue().
Slider slider = new Slider();
slider.setValue(25); // Establece el slider en 25
Integer value = slider.getValue();
System.out.println("Valor Actual del Slider: " + value);
Valores mínimo y máximo
Los valores mínimo y máximo definen el rango permitido del Slider, determinando los límites dentro de los cuales el botón del Slider puede moverse. Por defecto, el rango se establece de 0 a 100, pero puedes personalizar estos valores según tus necesidades.
Los intervalos en el Slider tienen un paso por defecto de 1, lo que significa que el número de intervalos se determina por el rango. Por ejemplo:
- Un Slider con un rango de 0 a 10 tendrá 10 intervalos.
- Un Slider con un rango de 0 a 100 tendrá 100 intervalos.
Estos intervalos están distribuidos uniformemente a lo largo de la pista del slider, con su espaciado dependiendo de las dimensiones del Slider.
A continuación se muestra un ejemplo de creación de un Slider con un rango personalizado:
Mostrar Código
- DonationSliderView.java
Configuración de ticks
El componente Slider ofrece una configuración flexible de ticks, permitiéndote personalizar cómo se muestran las marcas de ticks y cómo interactúa el knob del slider con ellas. Esto incluye ajustar el espaciado de ticks mayores y menores, mostrar/ocultar marcas de ticks y permitir el ajuste a las marcas de ticks para una entrada precisa del usuario.
Espaciado de ticks mayores y menores
Puedes definir el espaciado para las marcas de ticks mayores y menores, que determina con qué frecuencia aparecen en la pista del Slider:
- Las marcas de ticks mayores son más grandes y a menudo etiquetadas para representar valores clave.
- Las marcas de ticks menores son más pequeñas y aparecen entre las marcas mayores para ofrecer intervalos más finos.
Establece el espaciado de ticks utilizando los siguientes métodos setMajorTickSpacing() y setMinorTickSpacing():
slider.setMajorTickSpacing(10); // Ticks mayores cada 10 unidades
slider.setMinorTickSpacing(2); // Ticks menores cada 2 unidades
Mostrar u ocultar ticks
Puedes alternar la visibilidad de las marcas de ticks usando el método setTicksVisible(). Por defecto, las marcas de ticks están ocultas.
slider.setTicksVisible(true); // Mostrar marcas de ticks
slider.setTicksVisible(false); // Ocultar marcas de ticks
Ajuste
Para asegurar que el knob del Slider se alinee con la marca de tick más cercana durante la interacción del usuario, habilita el ajuste utilizando el método setSnapToTicks():
slider.setSnapToTicks(true); // Habilitar ajuste
Aquí hay un ejemplo de un Slider completamente configurado que muestra configuraciones de ticks mayores y menores junto con la capacidad de ajuste para ajustes precisos:
Mostrar Código
- SliderTickSpacingView.java
Orientación e inversión
El componente Slider admite dos orientaciones: horizontal (por defecto) y vertical. Puedes cambiar la orientación para adaptarla a tu diseño de interfaz de usuario y requisitos de aplicación.
Además de la orientación, el Slider también puede ser invertido. Por defecto:
- Un
Sliderhorizontal va de mínimo (izquierda) a máximo (derecha). - Un
Slidervertical va de mínimo (abajo) a máximo (arriba).
Cuando se invierte, esta dirección se invierte. Usa el método setInverted(true) para habilitar la inversión.
Mostrar Código
- SliderOrientationView.java
Etiquetas
El componente Slider admite etiquetas en las marcas de ticks para ayudar a los usuarios a interpretar los valores más fácilmente. Puedes usar etiquetas numéricas predeterminadas o proporcionar etiquetas personalizadas, y puedes alternar su visibilidad según sea necesario.
Etiquetas predeterminadas
Por defecto, el slider puede mostrar etiquetas numéricas en las marcas de ticks mayores. Estos valores son determinados por la configuración de setMajorTickSpacing(). Para habilitar las etiquetas predeterminadas, usa:
slider.setLabelsVisible(true);
Etiquetas personalizadas
Puedes reemplazar las etiquetas numéricas predeterminadas con texto personalizado usando el método setLabels(). Esto es útil cuando deseas mostrar valores más significativos (por ejemplo, temperatura, moneda o categorías).
Map<Integer, String> customLabels = Map.of(
0, "Frío",
30, "Fresco",
50, "Moderado",
80, "Cálido",
100, "Caliente"
);
slider.setLabels(customLabels);
slider.setLabelsVisible(true);
Alternar visibilidad de etiquetas
Ya sea que estés utilizando etiquetas predeterminadas o personalizadas, puedes controlar su visibilidad con setLabelsVisible(true) o ocultarlas con setLabelsVisible(false).
Mostrar Código
- SliderLabelsView.java
Tooltips
Los tooltips mejoran la usabilidad mostrando el valor del Slider directamente encima o debajo del knob, ayudando a los usuarios a realizar ajustes más precisos. Puedes configurar el comportamiento, la visibilidad y el formato del tooltip según tus necesidades.
Para habilitar los tooltips, utiliza el método setTooltipVisible(). Por defecto, los tooltips están desactivados:
slider.setTooltipVisible(true); // Habilitar tooltips
slider.setTooltipVisible(false); // Deshabilitar tooltips
Los tooltips también se pueden configurar para aparecer solo cuando el usuario interactúa con el Slider. Usa el método setTooltipVisibleOnSlideOnly() para habilitar este comportamiento. Esto es especialmente útil para reducir el desorden visual mientras se proporciona retroalimentación útil durante la interacción.
Aquí hay un ejemplo de un Slider completamente configurado con tooltips:
Personalización del tooltip
Por defecto, el Slider muestra un tooltip con su valor actual. Si deseas personalizar este texto, usa el método setTooltipText(). Esto es útil cuando quieres que el tooltip muestre texto estático o descriptivo en lugar del valor en vivo.
También puedes usar una expresión de JavaScript para formatear el tooltip dinámicamente. Si tu expresión incluye la palabra clave return, se utiliza tal cual. Si no, se envuelve automáticamente con return y ; para formar una función válida. Por ejemplo:
// Muestra valor seguido de un signo de dólar
slider.setTooltipText("return x + '$'");
O simplemente:
// Interpretado como: return x + ' unidades';
slider.setTooltipText("x + ' unidades'");
Estilización
Temas
El Slider viene con 6 temas integrados para una rápida estilización sin el uso de CSS. El uso de temas está soportado mediante una clase enum incorporada.
A continuación se muestran sliders con cada uno de los Temas soportados aplicados:
Mostrar Código
- SliderThemesView.java