Saltar al contenido principal

Slider

Abrir en ChatGPT
Sombra dwc-slider 24.10
Java API

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

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.

Valor por defecto

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

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

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 Slider horizontal va de mínimo (izquierda) a máximo (derecha).
  • Un Slider vertical 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

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

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

Loading...