JavaFX - TabPane / Tab如何使标签标题不可见?

时间:2012-12-18 12:30:19

标签: javafx-2 javafx

我是JavaFX的新手并且遇到了一些麻烦:

我有一个带有多个Tabs的TabPane,我想让Tab标题不可见。因此,用户不应该通过点击标题来更改标签,但它会以不同的方式从菜单中更改。

如何使此标签标题不可见/隐藏?这就是问题所在。我不想隐藏整个标签或禁用或类似的东西,只是标题。

或者你可能有另一个完全不同的想法,如何在JavaFX中解决这个问题。也许与另一个控件???

感谢任何线索。

3 个答案:

答案 0 :(得分:5)

如果您未使用Tabs,则不需要TabPane

您只需引入内容窗格列表,然后根据菜单命令进行切换即可。

您可以在下一个问题中找到代码示例:How can I implement the functionality of awt.CardLayout in my javaFX 2.0 application?

答案 1 :(得分:3)

我的研究结论:在JavaFX中无法做到这一点。 TabPane标题可以位于控件的顶部,左侧,右侧和底部,但不能隐藏。

答案 2 :(得分:0)

您可以通过将TabPane包装在AnchorPane(根容器)中并根据需要将TabPane的topAnchor设置为负数来实现此目的。

Java代码:

...
AnchorPane.setTopAnchor(myTabPane, -29.0);
AnchorPane.setBottomAnchor(myTabPane, 0);
AnchorPane.setLeftAnchor(myTabPane, 0);
AnchorPane.setRightAnchor(myTabPane, 0);
...

也在FXML中:

<?xml version="1.0" encoding="UTF-8"?>

<?import javafx.scene.text.*?>
<?import javafx.scene.control.*?>
<?import java.lang.*?>
<?import javafx.scene.*?>
<?import javafx.scene.layout.*?>

<AnchorPane maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="400.0" prefWidth="600.0" xmlns="http://javafx.com/javafx/8" xmlns:fx="http://javafx.com/fxml/1">
   <children>
      <TabPane fx:id="myTabPane" prefHeight="200.0" prefWidth="200.0" tabClosingPolicy="UNAVAILABLE" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="-29.0">
        <tabs>
          <Tab fx:id="tab1" text="Tab 1">
            <content>
              <AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="180.0" prefWidth="200.0">
                     <children>
                        <Label text="Tab 1" />
                        <Button layoutX="35.0" layoutY="2.0" mnemonicParsing="false" text="Go to Tab 2 (non-functional currently)" />
                     </children>
                  </AnchorPane>
            </content>
          </Tab>
          <Tab fx:id="tab2" text="Tab 2">
            <content>
              <AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="180.0" prefWidth="200.0">
                     <children>
                        <Label text="Tab 2" />
                        <Button layoutX="35.0" layoutY="2.0" mnemonicParsing="false" text="Go to Tab 1 (non-functional currently)" />
                     </children>
                  </AnchorPane>
            </content>
          </Tab>
        </tabs>
      </TabPane>
   </children>
</AnchorPane>