如何在JavaFX中的选项卡窗格(TabPane)之间添加分隔线?

huangapple go评论94阅读模式
英文:

How do you add a split between tabpane in JavaFX?

问题

我创建了一个垂直的标签面板,但在每个标签之间添加水平线方面遇到了问题。

这是我的代码:

.tab *.tab-label {
    -fx-rotate: 90;
}

.tab {
    -fx-padding: 3em 0.5em;
}

.tab-pane .tab-header-area .tab {
    -fx-pref-height: 140;
    -fx-pref-width: 50;
    -fx-background-color: transparent;
}

这是结果的图片。

如何在JavaFX中的选项卡窗格(TabPane)之间添加分隔线?

我希望在每个标签之间有一条水平线来分隔它们。

英文:

I made a vertical tabpane but am having trouble adding a horizontal line between each label.

Here is what I have:

.tab *.tab-label {
    -fx-rotate: 90;
}

.tab {
    -fx-padding: 3em 0.5em;
}

.tab-pane .tab-header-area .tab {
    -fx-pref-height: 140;
    -fx-pref-width: 50;
    -fx-background-color: transparent;
}

Here is a picture of the result.

如何在JavaFX中的选项卡窗格(TabPane)之间添加分隔线?

And I want between each label to have a horizontal line to separate them.

答案1

得分: 1

您可以使用[`Separator`][1],结合一些CSS样式以及在选项卡的宽度和高度上设置最小值和最大值,来实现您想要的效果。

[![图片][2]][2]

*no-tab-background.css*

    .tab-pane .tab-header-area .tab {
        -fx-font-size: 20px;
        -fx-pref-height: 140;
        -fx-pref-width: 50;
        -fx-background-color: transparent;
        -fx-text-box-border: 紫色;
    }

*ShowTabs.java*

    package com.test.demo;

    import javafx.application.Application;
    import javafx.geometry.*;
    import javafx.scene.Scene;
    import javafx.scene.control.*;
    import javafx.scene.layout.*;
    import javafx.stage.Stage;
    
    public class ShowTabs extends Application {
    
        @Override
        public void start(Stage stage) throws Exception {
            TabPane tabPane = new TabPane();
    
            tabPane.setSide(Side.LEFT);
            tabPane.setTabMinWidth(20);
            tabPane.setTabMaxWidth(20);
            tabPane.setTabMinHeight(100);
            tabPane.setTabMaxHeight(100);
            tabPane.setTabClosingPolicy(TabPane.TabClosingPolicy.UNAVAILABLE);
            tabPane.getTabs().addAll(
                    makeTab("打开", "柠檬绸缎色"),
                    makeTab("关闭", "矢车菊蓝色"),
                    makeTab("存款", "浅粉红色"),
                    makeTab("取款", "珊瑚色"),
                    makeTab("显示", "军校蓝色")
            );
    
            tabPane.getStylesheets().add(
                    ShowTabs.class.getResource("no-tab-background.css").toExternalForm()
            );
    
            Scene scene = new Scene(new StackPane(tabPane));
            stage.setScene(scene);
            stage.show();
        }
    
        private Tab makeTab(String text, String background) {
            Tab tab = new Tab();
    
            Label label = new Label(text);
    
            Separator separator = new Separator();
            separator.setPadding(new Insets(0, 0, 10, 0));
    
            VBox tabHeaderLayout = new VBox(label, separator);
            tabHeaderLayout.setSpacing(5);
            tabHeaderLayout.setAlignment(Pos.CENTER);
            tabHeaderLayout.setMinWidth(Control.USE_PREF_SIZE);
            tabHeaderLayout.setPrefWidth(120);
            tabHeaderLayout.setMaxWidth(Control.USE_PREF_SIZE);
    
            Pane content = new Pane();
            content.setPrefSize(300, 300);
            content.setStyle("-fx-background-color: " + background + ";");
    
            tab.setGraphic(tabHeaderLayout);
            tab.setContent(content);
    
            return tab;
        }
    
        public static void main(String[] args) {
            launch(args);
        }
    }

作为选项卡的替代方法,可以使用超链接和可更改的内容窗格(类似于网页样式的菜单系统),参见:

 * https://stackoverflow.com/questions/13556637/how-to-have-menus-website-style-navigation-links-in-java-desktop-application

  [1]: https://openjfx.io/javadoc/15/javafx.controls/javafx/scene/control/Separator.html
  [2]: https://i.stack.imgur.com/uhogv.png
英文:

You can use a Separator with a little CSS styling and min and max settings on the tab width and height to achieve what you want.

如何在JavaFX中的选项卡窗格(TabPane)之间添加分隔线?

no-tab-background.css

.tab-pane .tab-header-area .tab {
    -fx-font-size: 20px;
    -fx-pref-height: 140;
    -fx-pref-width: 50;
    -fx-background-color: transparent;
    -fx-text-box-border: purple;
}

ShowTabs.java

package com.test.demo;

import javafx.application.Application;
import javafx.geometry.*;
import javafx.scene.Scene;
import javafx.scene.control.*;
import javafx.scene.layout.*;
import javafx.stage.Stage;

public class ShowTabs extends Application {

    @Override
    public void start(Stage stage) throws Exception {
        TabPane tabPane = new TabPane();

        tabPane.setSide(Side.LEFT);
        tabPane.setTabMinWidth(20);
        tabPane.setTabMaxWidth(20);
        tabPane.setTabMinHeight(100);
        tabPane.setTabMaxHeight(100);
        tabPane.setTabClosingPolicy(TabPane.TabClosingPolicy.UNAVAILABLE);
        tabPane.getTabs().addAll(
                makeTab("Open", "lemonchiffon"),
                makeTab("Close", "cornflowerblue"),
                makeTab("Deposit", "lightpink"),
                makeTab("Withdraw", "coral"),
                makeTab("Display", "cadetblue")
        );

        tabPane.getStylesheets().add(
                ShowTabs.class.getResource("no-tab-background.css").toExternalForm()
        );

        Scene scene = new Scene(new StackPane(tabPane));
        stage.setScene(scene);
        stage.show();
    }

    private Tab makeTab(String text, String background) {
        Tab tab = new Tab();

        Label label = new Label(text);

        Separator separator = new Separator();
        separator.setPadding(new Insets(0, 0, 10, 0));

        VBox tabHeaderLayout = new VBox(label, separator);
        tabHeaderLayout.setSpacing(5);
        tabHeaderLayout.setAlignment(Pos.CENTER);
        tabHeaderLayout.setMinWidth(Control.USE_PREF_SIZE);
        tabHeaderLayout.setPrefWidth(120);
        tabHeaderLayout.setMaxWidth(Control.USE_PREF_SIZE);

        Pane content = new Pane();
        content.setPrefSize(300, 300);
        content.setStyle("-fx-background-color: " + background + ";");

        tab.setGraphic(tabHeaderLayout);
        tab.setContent(content);

        return tab;
    }

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

For an alternative approach to tabs which uses hyperlinks and a changeable content pane (like a web page style menu system), see:

huangapple
  • 本文由 发表于 2020年10月17日 04:28:50
  • 转载请务必保留本文链接:https://go.coder-hub.com/64396014.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定