ProgressBar
的默认外观是一个蓝色条,随着进度的增加在控件中移动:
我(我的火车)的图像作为我的应用程序中的资源。是否有可能使用CSS(或其他技术)使图像在控件上进行而不是默认的蓝色条?它应该看起来像:
答案 0 :(得分:2)
只需使用外部CSS文件并在栏上设置背景图像。条形本身由样式类Region
bar
表示(请参阅docs),因此您只需要类似
.progress-bar > .bar {
-fx-background-image: url("http://upload.wikimedia.org/wikipedia/commons/c/ce/Train_icon_small.png");
-fx-background-position: right ;
-fx-background-color: transparent ;
-fx-background-repeat: repeat-x ;
}
完整示例:
import javafx.application.Application;
import javafx.concurrent.Task;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.ProgressBar;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;
public class TrainProgressBar extends Application {
@Override
public void start(Stage primaryStage) {
ProgressBar progressBar = new ProgressBar();
progressBar.setProgress(0);
Button startButton = new Button("Start");
startButton.setOnAction(e -> {
startButton.setDisable(true);
Task<Void> task = new Task<Void>() {
@Override
public Void call() throws Exception {
for (int i = 0; i < 100; i++) {
Thread.sleep(20);
updateProgress(i, 100);
}
updateProgress(100, 100);
return null ;
}
};
progressBar.progressProperty().bind(task.progressProperty());
task.setOnSucceeded(evt -> startButton.setDisable(false));
new Thread(task){{setDaemon(true);}}.start();
});
VBox root = new VBox(15, progressBar, startButton);
Scene scene = new Scene(root, 250, 100);
scene.getStylesheets().add("train-progress-bar.css");
primaryStage.setScene(scene);
primaryStage.show();
}
public static void main(String[] args) {
launch(args);
}
}
使用train-progress-bar.css:
.root {
-fx-padding: 10 ;
-fx-alignment: center ;
}
.progress-bar > .bar {
-fx-background-image: url(http://upload.wikimedia.org/wikipedia/commons/c/ce/Train_icon_small.png);
-fx-background-position: right ;
-fx-background-color: transparent ;
-fx-background-repeat: repeat-x ;
}
答案 1 :(得分:1)
.parentOfProgress {
padding: 1px;
border: 1px solid #808080;
width: 144px;
}
progress {
height:5px !important;
background: #fafafa !important;
}
progress::-webkit-progress-bar {
background: #fafafa !important;
height: 5px !important;
}
progress::-webkit-progress-value {
background: #06c !important;
}
progress::-moz-progress-bar {
background: #fafafa !important;
height: 5px !important;
}