拖动滑块时更新标签

时间:2014-04-01 08:20:36

标签: slider javafx label drag

我在我的javaFX项目中使用了Slider,并且当我移动滑块时,我有Label更新。

我希望Label在我拖动Slider时进行更新,而不仅仅是在删除拖动时。

这是我的代码:

 betSlider.valueChangingProperty().addListener(new ChangeListener<Boolean>() {
            @Override
            public void changed(ObservableValue<? extends Boolean> source, Boolean oldValue, Boolean newValue) {
                betLabel.textProperty().setValue(String.valueOf((int)betSlider.getValue()));
  } });

6 个答案:

答案 0 :(得分:8)

您只需将valueChangingProperty()更改为valueProperty()和TADA即可,您可以随意使用!

这里附有一个小样本:

import javafx.application.Application;
import javafx.beans.value.ChangeListener;
import javafx.beans.value.ObservableValue;
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 Demo extends Application {

    @Override
    public void start(Stage primaryStage) {
        // Add a scene
        VBox root = new VBox();
        Scene scene = new Scene(root, 500, 200);

        final Label betLabel = new Label("sdsd");

        final Slider betSlider = new Slider();
        betSlider.valueProperty().addListener(new ChangeListener() {

            @Override
            public void changed(ObservableValue arg0, Object arg1, Object arg2) {
                betLabel.textProperty().setValue(
                        String.valueOf((int) betSlider.getValue()));

            }
        });

        root.getChildren().addAll(betSlider, betLabel);
        betLabel.textProperty().setValue("abc");

        // show the stage
        primaryStage.setTitle("Demo");
        primaryStage.setScene(scene);
        primaryStage.show();
    }

    public static void main(String[] args) {
        launch(args);
    }
}

答案 1 :(得分:8)

如果你想完全使用FXML,你可以这样做:

<TextField prefWidth="50" text="${speedSlider.value}"/>
<Slider fx:id="speedSlider" orientation="HORIZONTAL" prefWidth="300"
        min="60" max="100000" blockIncrement="100"/>

答案 2 :(得分:6)

将标签的textProperty绑定到滑块的valueProperty。

绑定中需要进行格式转换才能使其正常工作。

Itachi的valueProperty()ChangeListener或绑定都可以。

11

import javafx.application.Application;
import javafx.beans.binding.Bindings;
import javafx.scene.Scene;
import javafx.scene.control.*;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;

public class Slide extends Application {
    @Override public void start(Stage stage) {   
        Label  label  = new Label();
        Slider slider = new Slider(1, 11, 5);

        label.textProperty().bind(
            Bindings.format(
                "%.2f",
                slider.valueProperty()
            )
        );

        VBox layout = new VBox(10, label, slider);
        layout.setStyle("-fx-padding: 10px; -fx-alignment: baseline-right");

        stage.setScene(new Scene(layout));
        stage.setTitle("Goes to");
        stage.show();
    }

    public static void main(String[] args) { launch(args); }
}

答案 3 :(得分:0)

如果你在JavaFX 8中有一个滑块,你可以这样做:

slider().addListener(e -> {
    // Your code here could be anything.
});

答案 4 :(得分:0)

添加对我来说似乎更简单易用的替代方法:

给出一个名为slMySlider的滑块和一个名为lblMySlider的标签

  1. 将MouseEvent.MOUSE_DRAGGED事件处理程序添加到滑块,并使其调用帮助程序方法:
slMySlider.addEventHandler(MouseEvent.MOUSE_DRAGGED, this::changeLabelHandler);
  1. 让helper方法更改标签的文本:
private void changeLabelHandler(MouseEvent e) {
        lblMySlider.setText("Value: " + String.format("%1.2f", slMySlider.getValue()));
    }

答案 5 :(得分:0)

slider.valueProperty().addListener((observable, oldValue, newValue) ->
label.setText("sliderNameLabel: " + newValue));