我正在尝试实现Slider,以便用户只能按给定的增量拖动。我通过使用Slider API尝试了不同的方式,但没有得到想要的结果。以下是我尝试过的快速演示。我期望仅以10的增量拖动拇指,而不用中间值。 snapToTicks可以满足我的要求,但是仅在完成拖动之后。我试图在达到下一个所需的块增量之前不移动拇指。
任何人都可以让我知道如何实现这一目标。下面是拖动时的屏幕截图。
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();
}
}
答案 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()
而不是圆形,则会获得更直观的拇指操作。