Hybrid of slider with progress bar JavaFX

后端 未结 3 465
孤独总比滥情好
孤独总比滥情好 2021-01-05 11:15

I want to handle click on ProgressBar like on slider. and learn a percent of track. I would use slider instead progressbar but it doesn\'t have a highlighted track until th

3条回答
  •  [愿得一人]
    2021-01-05 11:31

    Here is another approach. Real hybrid of slider and progress bar :). Meet SlidoProgressBar!

    public class SlidoProgressBarDemo extends Application {
    
        @Override
        public void start(Stage stage) {
            Group root = new Group();
            Scene scene = new Scene(root);
            scene.getStylesheets().add(this.getClass().getResource("style.css").toExternalForm());
            stage.setScene(scene);
            stage.setTitle("Progress Controls");
    
            double sliderWidth = 200;
    
            final Slider slider = new Slider();
            slider.setMin(0);
            slider.setMax(50);
            slider.setMinWidth(sliderWidth);
            slider.setMaxWidth(sliderWidth);
    
            final ProgressBar pb = new ProgressBar(0);
            pb.setMinWidth(sliderWidth);
            pb.setMaxWidth(sliderWidth);
    
            final ProgressIndicator pi = new ProgressIndicator(0);
    
            slider.valueProperty().addListener(new ChangeListener() {
                public void changed(ObservableValue ov,
                        Number old_val, Number new_val) {
                    pb.setProgress(new_val.doubleValue() / 50);
                    pi.setProgress(new_val.doubleValue() / 50);
                }
            });
    
            StackPane pane = new StackPane();
    
            pane.getChildren().addAll(pb, slider);
    
            final HBox hb = new HBox();
            hb.setSpacing(5);
            hb.setAlignment(Pos.CENTER);
            hb.getChildren().addAll(pane, pi);
    
            scene.setRoot(hb);
            stage.show();
        }
    
        public static void main(String[] args) {
            launch(args);
        }
    }
    

    with style.css:

    .slider .track {
        -fx-background-color:null;  /* Hide the track */
        -fx-background-insets: 1 0 -1 0, 0, 1;
        -fx-background-radius: 2.5, 2.5, 1.5;
        -fx-padding: 0.208333em; /* 2.5 */
    }
    

    The basic logic is to put slider and progress into stackpane. Give them the same width. Bind the progress values of them. Hide the track of the slider.
    Output:
    enter image description here

提交回复
热议问题