如何使用选项卡式窗格

原文: https://docs.oracle.com/javase/tutorial/uiswing/components/tabbedpane.html

使用 JTabbedPane 类,您可以拥有多个组件,例如面板,共享相同的空间。用户通过选择与所需组件对应的选项卡来选择要查看的组件。如果您想要没有选项卡界面的类似功能,可以使用卡布局而不是选项卡式窗格。

创建选项卡式窗格

要创建选项卡式窗格,请实例化JTabbedPane,创建要显示的组件,然后使用addTab方法将组件添加到选项卡式窗格。

下图介绍了一个名为TabbedPaneDemo的应用程序,它有一个带有四个选项卡的选项卡式窗格。

A screenshot of TabbedPaneDemo


Try this:

  1. 单击“启动”按钮以使用 Java™Web Start下载 JDK 7 或更高版本)运行 TabbedPaneDemo。或者,要自己编译并运行示例,请参考示例索引Launches the TabbedPaneDemo Application

  2. 将光标放在选项卡上。 出现与选项卡关联的工具提示。为方便起见,您可以在将组件添加到选项卡式窗格时指定工具提示文本。

  3. 单击选项卡。 选项卡式窗格显示与选项卡对应的组件。
  4. 通过输入其助记符来选择选项卡。 例如,在 Java 外观中,您可以通过键入 Alt-3 选择标记为“Tab 3”的选项卡。
  5. 在可滚动选项卡之间导航。 此示例提供可滚动选项卡。通过移动其左侧或右侧边界来调整对话框的大小,以使选项卡不适合对话框。选项卡旁边会显示滚动箭头。 单击箭头可查看其中一个隐藏的选项卡。 请注意,单击箭头只会显示隐藏的标签。它不会选择新选项卡。

正如TabbedPaneDemo示例所示,选项卡可以具有工具提示和助记符,并且它可以显示文本和图像。

标签放置

默认选项卡位置设置为TOP位置,如上所示。您可以使用setTabPlacement方法将标签位置更改为LEFTRIGHTTOPBOTTOM

选项卡窗格的代码

TabbedPaneDemo.java 中的以下代码在上一个示例中创建选项卡式窗格。请注意,不需要事件处理代码。 JTabbedPane对象为您处理鼠标和键盘事件。

  1. JTabbedPane tabbedPane = new JTabbedPane();
  2. ImageIcon icon = createImageIcon("images/middle.gif");
  3. JComponent panel1 = makeTextPanel("Panel #1");
  4. tabbedPane.addTab("Tab 1", icon, panel1,
  5. "Does nothing");
  6. tabbedPane.setMnemonicAt(0, KeyEvent.VK_1);
  7. JComponent panel2 = makeTextPanel("Panel #2");
  8. tabbedPane.addTab("Tab 2", icon, panel2,
  9. "Does twice as much nothing");
  10. tabbedPane.setMnemonicAt(1, KeyEvent.VK_2);
  11. JComponent panel3 = makeTextPanel("Panel #3");
  12. tabbedPane.addTab("Tab 3", icon, panel3,
  13. "Still does nothing");
  14. tabbedPane.setMnemonicAt(2, KeyEvent.VK_3);
  15. JComponent panel4 = makeTextPanel(
  16. "Panel #4 (has a preferred size of 410 x 50).");
  17. panel4.setPreferredSize(new Dimension(410, 50));
  18. tabbedPane.addTab("Tab 4", icon, panel4,
  19. "Does nothing at all");
  20. tabbedPane.setMnemonicAt(3, KeyEvent.VK_4);

如前面的代码所示,addTab方法处理在选项卡式窗格中设置选项卡的大部分工作。 addTab方法有多种形式,但它们都使用字符串标题和选项卡显示的组件。或者,您可以指定图标和工具提示字符串。文本或图标(或两者)可以为 null。创建选项卡的另一种方法是使用insertTab方法,该方法允许您指定要添加的选项卡的索引。请注意,addTab方法在此步骤中不允许索引指定。

切换到特定选项卡

使用 GUI 切换到特定选项卡有三种方法。

  1. 使用鼠标。 要切换到特定选项卡,用户可以使用鼠标单击它。
  2. 使用键盘箭头。JTabbedPane对象具有焦点时,可以使用键盘箭头从制表符切换到制表符。
  3. 使用关键助记符。 setMnemonicAt方法允许用户使用键盘切换到特定选项卡。例如,setMnemonicAt(3, KeyEvent.VK_4)使’4’成为第四个标签的助记符(在索引 3 处,因为索引从 0 开始);按 Alt-4 可显示第四个选项卡的组件。通常,助记符使用选项卡标题中的字符,然后自动加下划线。

要以编程方式切换到特定选项卡,请使用 setSelectedIndexsetSelectedComponent 方法。

标签中的首选大小

构建要添加到选项卡式窗格的组件时,请记住,无论选项卡式窗格的哪个子项可见,每个子级都会获得相同数量的空间来显示自身。选项卡式窗格的首选大小足以将其最高的子项显示在其首选高度,并将其最宽的子项显示在其首选宽度。同样,选项卡式窗格的最小大小取决于其所有子级的最大最小宽度和高度。

TabbedPaneDemo示例中,第四个面板的首选宽度和高度大于其他面板的宽度和高度。因此,标签窗格的优选尺寸刚好足以显示第四面板的优选尺寸。假设选项卡式窗格处于其首选大小,则每个面板都会获得完全相同的空间 - 410 像素宽和 50 高。如果您不了解首选尺寸的使用方法,请参阅布局管理的工作原理

带有自定义组件的选项卡

TabComponentsDemo示例引入了一个选项卡式窗格,其选项卡包含实际组件。自定义组件的使用为选项卡带来了按钮,组合框,标签和其他组件等新功能,并允许更复杂的用户交互。

这是一个选项卡式窗格,其选项卡上有关闭按钮。

A screenshot of TabComponentsDemo


Try this:

  1. 单击“启动”按钮以使用 Java™Web Start下载 JDK 7 或更高版本)运行 TabComponentsDemo。或者,要自己编译并运行示例,请参考示例索引Launches the TabComponentsDemo Application

  2. 将光标放在选项卡上。

  3. 通过单击选择一个选项卡(确保不要击中小十字架)。
  4. 用一个小十字架将光标放在其中一个小部件上。 十字架变成洋红色并被包围在一个正方形中。出现与关闭按钮关联的工具提示。 用鼠标左键单击十字形以关闭选项卡。
  5. 通过从“选项”菜单中选择“重置 JTabbedPane”项,恢复已删除的选项卡。
  6. 请注意,带有自定义组件的选项卡显示在原始选项卡式窗格选项卡的顶部。 要查看下面的选项卡,请打开“选项”菜单,然后清除“使用 TabComponents”复选框。
  7. 通过再次选中“使用 TabComponents”复选框,显示包含组件的选项卡。
  8. 关闭所有标签。现在选项卡式窗格为空。

删除标签

ButtonTabComponent.java 中的以下代码从选项卡式窗格中删除选项卡。请注意,事件处理代码是必需的。由于每个选项卡都包含一个真实的JButton对象,因此必须将ActionListener附加到关闭按钮。当用户单击该按钮时,actionPerformed方法确定其所属选项卡的索引并删除相应的选项卡。

  1. public void actionPerformed(ActionEvent e) {
  2. int i = pane.indexOfTabComponent(ButtonTabComponent.this);
  3. if (i != -1) {
  4. pane.remove(i);
  5. }
  6. }

将标题赋予自定义标签

以下代码取自 ButtonTabComponent.java ,显示自定义选项卡组件如何从原始选项卡式窗格选项卡获取标题。

  1. JLabel label = new JLabel(title) {
  2. public String getText() {
  3. int i = pane.indexOfTabComponent(ButtonTabComponent.this);
  4. if (i != -1) {
  5. return pane.getTitleAt(i);
  6. }
  7. return null;
  8. }
  9. };

下表列出了常用的JTabbedPane构造器和方法。使用选项卡式窗格的 API 分为以下几类:

方法或构造器 目的
JTabbedPane()

JTabbedPane(int) JTabbedPane(int,int) | 创建选项卡式窗格。第一个可选参数指定选项卡应显示的位置。默认情况下,选项卡显示在选项卡式窗格的顶部。您可以指定这些位置(在JTabbedPane接口中定义,JTabbedPane实现):TOPBOTTOMLEFTRIGHT。第二个可选参数指定选项卡布局策略。您可以指定其中一个策略(在JTabbedPane中定义): WRAP_TAB_LAYOUTSCROLL_TAB_LAYOUT 。 | | addTab(String,Icon,Component,String) addTab(String,Icon,Component) addTab(String,Component) | 在选项卡式窗格中添加新选项卡。第一个参数指定选项卡上的文本。可选的图标参数指定选项卡的图标。 component 参数指定选中选项卡时选项卡式窗格应显示的组件。第四个参数(如果存在)指定选项卡的工具提示文本。 | | void setTabLayoutPolicy(int) int getTabLayoutPolicy() | 当所有选项卡不适合单次运行时,设置或获取选项卡式窗格在布置选项卡时使用的策略。可能的值为WRAP_TAB_LAYOUTSCROLL_TAB_LAYOUT。默认策略为WRAP_TAB_LAYOUT。 | | void setTabPlacement(int) int getTabPlacement() | 设置或获取选项卡相对于内容的显示位置。可能的值(在SwingConstants中定义,由JTabbedPane实现)是TOPBOTTOMLEFTRIGHT。 |

方法 目的
insertTab(String,Icon,Component,String,int) 在指定索引处插入选项卡,其中第一个选项卡位于索引 0 处。参数与addTab相同。
去除(组分)

removeTabAt(int) | 删除与指定组件或索引对应的选项卡。 | | removeAll() | 删除所有标签。 | | int index 组件(组件) int indexOf(String) int indexOfTab(Icon) | 返回具有指定组件,标题或图标的选项卡的索引。 | | void setSelectedIndex(int) void setSelectedComponent(Component) | 选择具有指定组件或索引的选项卡。选择选项卡具有显示其关联组件的效果。 | | int getSelectedIndex() 组件 getSelectedComponent() | 返回所选选项卡的索引或组件。 |

方法 目的
void setComponentAt(int,Component)

Component getComponentAt(int) | 设置或获取与指定索引处的选项卡关联的组件。第一个选项卡位于索引 0 处。 | | void setTitleAt(int,String) String getTitleAt(int) | 设置或获取指定索引处的选项卡标题。 | | void setIconAt(int,Icon) Icon getIconAt(int) void setDisabledIconAt(int,Icon) Icon getDisabledIconAt(int) | 设置或获取指定索引处的选项卡显示的图标。 | | void setBackgroundAt(int,Color) Color getBackgroundAt(int) void setForegroundAt(int,Color) 颜色 getForegroundAt(int) | 设置或获取指定索引处选项卡使用的背景或前景颜色。默认情况下,选项卡使用选项卡式窗格的背景和前景颜色。例如,如果选项卡式窗格的前景为黑色,则除了使用setForegroundAt指定其他颜色的任何选项卡外,每个选项卡的标题均为黑色。 | | void setEnabledAt(int,boolean) boolean isEnabledAt(int) | 设置或获取指定索引处选项卡的启用状态。 | | void setMnemonicAt(int,int) int getMnemonicAt(int) | 设置或获取用于访问指定选项卡的键盘助记符。 | | void setDisplayedMnemonicIndexAt(int,int) int getDisplayedMnemonicIndexAt(int) | 设置或获取应该装饰哪个字符来表示助记符。当助记符在标签的标题中多次出现并且您不希望第一个出现下划线时,这非常有用。 | | void setToolTipTextAt(int,String) String getToolTipTextAt(int) | 设置或获取指定选项卡的工具提示上显示的文本。 |

方法 目的
void setTabComponentAt(int,Component) 设置负责为第一个参数指定的选项卡呈现标题或图标(或两者)的组件。指定空值时,JTabbedPane将呈现标题或图标。相同的组件不能用于多个选项卡。
组件 getTabComponentAt(int) 获取参数指定的索引处的选项卡的选项卡组件。如果指定的选项卡没有选项卡组件,则返回空值。
int indexOfTabComponent(Component) 检查指定的组件是否属于其中一个选项卡。返回相应选项卡的索引,如果没有这样的选项卡,则返回-1。

此表列出了使用JTabbedPane的示例,并指出了描述这些示例的位置。

在哪里描述 笔记
TabbedPaneDemo 这一页 演示一些选项卡式窗格功能,例如工具提示,图标,可滚动布局和助记符。
TabComponentsDemo 这一页 在选项卡上演示自定义组件。使用带有关闭按钮的选项卡式窗格。
BoxAlignmentDemo 如何使用 BoxLayout 使用JTabbedPane作为框架内容窗格的唯一子项。
BorderDemo 如何使用边框 以类似于BoxAlignmentDemo的方式使用其选项卡式窗格。
DialogDemo 如何使用对话框 在框架的内容窗格的中心有一个选项卡式窗格,其下方有一个标签。