我想使用(JavaFX)TabPane来显示20个不同选项卡的内容。这适用于标准TabPane,但是,当窗格点击一定数量的选项卡时,可以单击按钮/ ComboBox以单击其中一个未看到的选项卡。
我正在设计一个将在触摸屏上使用的功能,因此这并不理想。我认为拥有两行独立的标签会更直观。
如何向TabPane添加两行标签,或者,可以采取哪些措施来实现类似效果?谢谢你提前。
以下是一些重现我的意思的示例代码:
public class TabTest extends Application {
public static void main(String args[]) {
Application.launch(args);
}
@Override
public void start(Stage primaryStage) throws Exception {
primaryStage.setTitle("Tabs Test");
Group root = new Group();
Scene scene = new Scene(root, 450, 250, Color.WHITE);
TabPane tabPane = new TabPane();
BorderPane borderPane = new BorderPane();
for( int i = 0; i < 20; i++)
{
Tab tab = new Tab();
tab.setText("Tab " + i);
HBox hbox = new HBox();
hbox.getChildren().add(new Label("Tab " + i));
tab.setContent(hbox);
tabPane.getTabs().add(tab);
}
borderPane.prefHeightProperty().bind(scene.heightProperty());
borderPane.prefWidthProperty().bind(scene.widthProperty());
borderPane.setCenter(tabPane);
root.getChildren().add(borderPane);
primaryStage.setScene(scene);
primaryStage.show();
}
答案 0 :(得分:0)
TabPane
的标题页区域基本上是StackPane,因此我认为创建两行标签而不是一行非常容易。
我的想法是隐藏TabPane
的原始标签,并在ToggleButton
中放置一组ToggleGroup
个对象,然后将选择的标记与选项卡绑定。
这样您可以将“标签”添加到您想要的任何容器中(流量,网格等)。
真正极少的样本:
Main.java
public class Main extends Application {
TabPane tabPane;
private ToggleGroup toggleGroup;
@Override
public void start(Stage primaryStage) {
Group root = new Group();
Scene scene = new Scene(root, 700, 400, Color.WHITE);
primaryStage.setTitle("Tabs Test");
toggleGroup = new ToggleGroup();
toggleGroup.selectedToggleProperty().addListener(new ChangeListener<Toggle>() {
@Override
public void changed(ObservableValue<? extends Toggle> observable, Toggle oldValue, Toggle newValue) {
if (newValue == null)
toggleGroup.selectToggle(oldValue);
else
tabPane.getSelectionModel().select((Tab) newValue.getUserData());
}
});
tabPane = new TabPane();
tabPane.getStylesheets().add(getClass().getResource("application.css").toExternalForm());
VBox vboxToggleOuterContainer = new VBox();
HBox hboxToggleFirstRow = new HBox();
HBox hboxToggleSecondRow = new HBox();
vboxToggleOuterContainer.getChildren().addAll(hboxToggleFirstRow, hboxToggleSecondRow);
for (int i = 0; i < 20; i++) {
Tab tab = new Tab();
tab.setText("Tab " + i);
HBox hbox = new HBox();
hbox.getChildren().add(new Label("Tab " + i));
tab.setContent(hbox);
tabPane.getTabs().add(tab);
ToggleButton tb = new ToggleButton("Tab" + i);
tb.setToggleGroup(toggleGroup);
tb.setUserData(tab);
if (i < 10)
hboxToggleFirstRow.getChildren().add(tb);
else
hboxToggleSecondRow.getChildren().add(tb);
}
toggleGroup.selectToggle(toggleGroup.getToggles().get(0));
VBox vbox = new VBox();
vbox.getChildren().addAll(vboxToggleOuterContainer, tabPane);
vbox.fillWidthProperty().set(true);
root.getChildren().add(vbox);
primaryStage.setScene(scene);
primaryStage.show();
}
public static void main(String[] args) {
launch(args);
}
}
application.css
.tab-pane {
-fx-skin: "com.sun.javafx.scene.control.skin.TabPaneSkin";
-fx-tab-min-height: 0;
-fx-tab-max-height: 0;
}
.tab-pane .tab-header-area {
-fx-padding: 0 0 0 0;
}
.tab-pane .tab-header-area .headers-region .tab {
-fx-padding: 0 0 1 0;
}
这个例子实际上是最小的,只是显示了这个方法,你可以改进CSS以使控件更加花哨(或者如果你想要我还可以更新它,如果我有时间的话)。