Slider
Le composant Slider offre aux utilisateurs un moyen de sélectionner une valeur numérique en faisant glisser un bouton le long d'une piste entre une limite minimale et maximale. Les intervalles de pas, les marques de graduation et les étiquettes peuvent être configurés pour guider la sélection.
Bases
Le Slider est conçu pour fonctionner immédiatement, sans nécessiter de configuration supplémentaire pour fonctionner efficacement. Par défaut, il couvre une plage de 0 à 100 avec une valeur de départ de 50, ce qui le rend idéal pour une intégration rapide dans n'importe quelle application. Pour des cas d'utilisation plus spécifiques, le Slider peut être personnalisé avec des propriétés telles que l'orientation, les marques de graduation, les étiquettes et les infobulles.
Voici un exemple de Slider permettant aux utilisateurs d'ajuster le niveau de volume dans une plage prédéfinie :
Afficher le code
- Java
Valeur du Slider
La valeur du Slider représente la position actuelle du bouton sur le curseur et est définie comme un entier dans la plage du Slider. Cette valeur se met à jour dynamiquement au fur et à mesure que l'utilisateur interagit avec le curseur, en faisant de cette propriété un élément essentiel pour suivre l'entrée de l'utilisateur.
Par défaut, le Slider commence avec une valeur de 50, en supposant la plage par défaut de 0 à 100.
Définir et obtenir la valeur
Vous pouvez définir la valeur du Slider lors de l'initialisation ou la mettre à jour plus tard en utilisant la méthode setValue(). Pour récupérer la valeur actuelle, utilisez la méthode getValue().
Slider slider = new Slider();
slider.setValue(25); // Définit le curseur à 25
Integer value = slider.getValue();
System.out.println("Valeur actuelle du Slider : " + value);
Valeurs minimales et maximales
Les valeurs minimales et maximales définissent la plage autorisée du Slider, déterminant les limites dans lesquelles le bouton du Slider peut se déplacer. Par défaut, la plage est définie de 0 à 100, mais vous pouvez personnaliser ces valeurs selon vos besoins.
Les intervalles sur le Slider ont un pas par défaut de 1, ce qui signifie que le nombre d'intervalles est déterminé par la plage. Par exemple :
- Un Slider avec une plage de 0 à 10 aura 10 intervalles.
- Un Slider avec une plage de 0 à 100 aura 100 intervalles.
Ces intervalles sont répartis uniformément le long de la piste du curseur, l'espacement dépendant des dimensions du Slider.
Voici un exemple de création d'un Slider avec une plage personnalisée :
Afficher le code
- Java
Configuration des graduations
Le composant Slider offre une configuration flexible des graduations, vous permettant de personnaliser la façon dont les marques de graduation sont affichées et comment le bouton du curseur interagit avec elles. Cela inclut l'ajustement de l'espacement des graduations majeures et mineures, l'affichage/cachage des marques de graduation et l'activation de l'accrochage aux marques de graduation pour des saisies plus précises de l'utilisateur.
Espacement des graduations majeures et mineures
Vous pouvez définir l'espacement des marques de graduation majeures et mineures, ce qui détermine la fréquence à laquelle elles apparaissent sur la piste du Slider :
- Les graduations majeures sont plus grandes et souvent étiquetées pour représenter des valeurs clés.
- Les graduations mineures sont plus petites et apparaissent entre les graduations majeures pour offrir des intervalles plus fins.
Définissez l'espacement des graduations en utilisant les méthodes suivantes setMajorTickSpacing() et setMinorTickSpacing() :
slider.setMajorTickSpacing(10); // Graduations majeures tous les 10 unités
slider.setMinorTickSpacing(2); // Graduations mineures toutes les 2 unités
Afficher ou masquer les graduations
Vous pouvez basculer la visibilité des marques de graduation à l'aide de la méthode setTicksVisible(). Par défaut, les marques de graduation sont cachées.
slider.setTicksVisible(true); // Afficher les marques de graduation
slider.setTicksVisible(false); // Masquer les marques de graduation
Accrochage
Pour garantir que le bouton du Slider s'aligne avec la marque de graduation la plus proche lors de l'interaction de l'utilisateur, activez l'accrochage en utilisant la méthode setSnapToTicks() :
slider.setSnapToTicks(true); // Activer l'accrochage
Voici un exemple d'un Slider entièrement configuré montrant les paramètres des graduations majeures et mineures ainsi que la capacité d'accrochage pour des ajustements précis :
Afficher le code
- Java
Orientation et inversion
Le composant Slider prend en charge deux orientations : horizontale (défaut) et verticale. Vous pouvez modifier l'orientation pour convenir à votre mise en page d'interface utilisateur et aux exigences de votre application.
En plus de l'orientation, le Slider peut également être inversé. Par défaut :
- Un
Sliderhorizontal va de minimum (gauche) à maximum (droite). - Un
Slidervertical va de minimum (bas) à maximum (haut).
Lorsque vous inversez, cette direction est inversée. Utilisez la méthode setInverted(true) pour activer l'inversion.
Afficher le code
- Java
Étiquettes
Le composant Slider prend en charge des étiquettes sur les marques de graduation pour aider les utilisateurs à interpréter plus facilement les valeurs. Vous pouvez utiliser des étiquettes numériques par défaut ou fournir des étiquettes personnalisées, et vous pouvez basculer leur visibilité selon vos besoins.
Étiquettes par défaut
Par défaut, le curseur peut afficher des étiquettes numériques aux marques de graduation majeures. Ces valeurs sont déterminées par le paramètre setMajorTickSpacing(). Pour activer les étiquettes par défaut, utilisez :
slider.setLabelsVisible(true);
Étiquettes personnalisées
Vous pouvez remplacer les étiquettes numériques par défaut par un texte personnalisé à l'aide de la méthode setLabels(). Cela est utile lorsque vous souhaitez afficher des valeurs plus significatives (par exemple, température, monnaie ou catégories).
Map<Integer, String> customLabels = Map.of(
0, "Froid",
30, "Frais",
50, "Modéré",
80, "Chaud",
100, "Très chaud"
);
slider.setLabels(customLabels);
slider.setLabelsVisible(true);
Basculer la visibilité des étiquettes
Que vous utilisiez des étiquettes par défaut ou personnalisées, vous pouvez contrôler leur visibilité avec setLabelsVisible(true) ou les masquer avec setLabelsVisible(false).
Afficher le code
- Java
Infobulles
Les infobulles améliorent l'utilisabilité en affichant la valeur du Slider directement au-dessus ou en dessous du bouton, aidant les utilisateurs à faire des ajustements plus précis. Vous pouvez configurer le comportement, la visibilité et le format de l'infobulle selon vos besoins.
Pour activer les infobulles, utilisez la méthode setTooltipVisible(). Par défaut, les infobulles sont désactivées :
slider.setTooltipVisible(true); // Activer les infobulles
slider.setTooltipVisible(false); // Désactiver les infobulles
Les infobulles peuvent également être configurées pour n'apparaître que lorsque l'utilisateur interagit avec le Slider. Utilisez la méthode setTooltipVisibleOnSlideOnly() pour activer ce comportement. Cela est particulièrement utile pour réduire le désordre visuel tout en fournissant des retours utiles pendant l'interaction.
Voici un exemple d'un Slider entièrement configuré avec des infobulles :
Personnalisation des infobulles
Par défaut, le Slider affiche une infobulle avec sa valeur actuelle. Si vous souhaitez personnaliser ce texte, utilisez la méthode setTooltipText(). Cela est utile lorsque vous souhaitez que l'infobulle affiche un texte statique ou descriptif au lieu de la valeur en direct.
Vous pouvez également utiliser une expression JavaScript pour formater l'infobulle dynamiquement. Si votre expression inclut le mot clé return, elle est utilisée telle quelle. Sinon, elle est automatiquement enveloppée avec return et ; pour former une fonction valide. Par exemple :
// Affiche la valeur suivie d'un signe dollar
slider.setTooltipText("return x + '$'");
Ou simplement :
// Interprété comme : return x + ' unités';
slider.setTooltipText("x + ' unités'");
Style
Thèmes
Le Slider propose 6 thèmes intégrés pour un style rapide sans utilisation de CSS. La thématique est prise en charge par l'utilisation d'une classe énumérée intégrée.
Voici des curseurs avec chacun des thèmes pris en charge appliqués :
Afficher le code
- Java