Я хочу создать панель вкладок с значками, подобными панели конфигурации Firefox с JavaFX:
Есть ли какой-нибудь пример, который я могу использовать, чтобы увидеть, как это реализовать?
Я хочу создать панель вкладок с значками, подобными панели конфигурации Firefox с JavaFX:
Есть ли какой-нибудь пример, который я могу использовать, чтобы увидеть, как это реализовать?
Вкладки, как и многие другие элементы в JavaFX, имеют метод под названием setGraphic(Node value)
, в который вы можете поместить любой JavaFX node. Пример:
import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.control.Label;
import javafx.scene.control.Tab;
import javafx.scene.control.TabPane;
import javafx.scene.layout.BorderPane;
import javafx.scene.layout.HBox;
import javafx.scene.paint.Color;
import javafx.scene.shape.Circle;
import javafx.stage.Stage;
public class TabPaneTest extends Application {
public static void main(String[] args) {
Application.launch(args);
}
@Override
public void start(Stage primaryStage) {
primaryStage.setTitle("Tabs");
Group root = new Group();
Scene scene = new Scene(root, 400, 250, Color.WHITE);
TabPane tabPane = new TabPane();
BorderPane borderPane = new BorderPane();
for (int i = 0; i < 5; i++) {
Tab tab = new Tab();
tab.setGraphic(new Circle(0, 0, 10));
HBox hbox = new HBox();
hbox.getChildren().add(new Label("Tab" + i));
hbox.setAlignment(Pos.CENTER);
tab.setContent(hbox);
tabPane.getTabs().add(tab);
}
// bind to take available space
borderPane.prefHeightProperty().bind(scene.heightProperty());
borderPane.prefWidthProperty().bind(scene.widthProperty());
borderPane.setCenter(tabPane);
root.getChildren().add(borderPane);
primaryStage.setScene(scene);
primaryStage.show();
}
}
Результат:
Я знаю его старый поток, но я не нашел прямого ответа нигде. Поэтому я подумал о том, чтобы опубликовать его, чтобы он был полезен для его поиска.
Это то, что я сделал, чтобы получить вкладку, такую как экран настроек Firefox.
Добавьте изображение на вкладку с помощью setGraphics и добавьте следующий код в файл css приложения. Размер моего изображения был 48x48. Так что я пошел на рост как 70.
.tab-label {
-fx-content-display: top;
}
.tab-pane {
-fx-tab-min-height: 70;
-fx-tab-max-height: 70;
}
Как добавить изображение непосредственно из URL-адреса изображения:
Tab tab = new Tab();
tab.setGraphic(buildImage("patch/to/image");
// Helper method to create image from image patch
private static ImageView buildImage(String imgPatch) {
Image i = new Image(imgPatch);
ImageView imageView = new ImageView();
//You can set width and height
imageView.setFitHeight(16);
imageView.setFitWidth(16);
imageView.setImage(i);
return imageView;
}