JavaFX Slider:如何仅以增量方式拖动滑块

时间:2019-06-12 06:45:53

标签: javafx slider javafx-8

我正在尝试实现Slider,以便用户只能按给定的增量拖动。我通过使用Slider API尝试了不同的方式,但没有得到想要的结果。以下是我尝试过的快速演示。我期望仅以10的增量拖动拇指,而不用中间值。 snapToTicks可以满足我的要求,但是仅在完成拖动之后。我试图在达到下一个所需的块增量之前不移动拇指。

任何人都可以让我知道如何实现这一目标。下面是拖动时的屏幕截图。

enter image description here

import javafx.application.Application;
import javafx.geometry.Insets;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.control.Label;
import javafx.scene.control.Slider;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;

public class SliderDemo extends Application {

    public static void main(String... args){
        Application.launch(args);
    }

    @Override
    public void start(Stage stage) throws Exception {

        Label label = new Label();
        label.setStyle("-fx-font-size:30px");

        Slider slider = new Slider(5,240,5);
        slider.setBlockIncrement(10);
        slider.setMajorTickUnit(10);
        slider.setMinorTickCount(0);
        slider.setShowTickLabels(true);
        slider.setShowTickMarks(true);
        slider.setSnapToTicks(true);

        slider.valueProperty().addListener((obs,old,val)->label.setText((int)Math.round(val.doubleValue())+""));
        VBox root = new VBox(slider,label);
        root.setAlignment(Pos.CENTER);
        root.setPadding(new Insets(20));
        root.setSpacing(20);

        Scene scene = new Scene(root,600,200);
        stage.setScene(scene);
        stage.show();
    }
}

1 个答案:

答案 0 :(得分:4)

解决方案是直接在侦听器内部设置滑块的值。不会再次调用该监听器

final ChangeListener<Number> numberChangeListener = (obs, old, val) -> {
    final double roundedValue = Math.floor(val.doubleValue() / 10.0) * 10.0;
    slider.valueProperty().set(roundedValue);
    label.setText(Double.toString(roundedValue));
};

slider.valueProperty().addListener(numberChangeListener);

如果您使用Math.floor()而不是圆形,则会获得更直观的拇指操作。