如何使用分隔符

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

JSeparator 类提供水平或垂直分界线或空白空间。它最常用于菜单和工具栏。实际上,您甚至不知道存在JSeparator类就可以使用分隔符,因为菜单工具栏提供了方便的方法来创建和添加为其容器定制的分隔符。分隔符有点类似于边框,除了它们是真正的组件,因此,它们被绘制在容器内,而不是在特定组件的边缘周围。

这是一个菜单的图片,它有三个分隔符,用于将菜单分成四组项目:

A menu with 4 parts, as indicated by 3 separators

将菜单项和分隔符添加到菜单的代码非常简单,可以归结为以下内容:

  1. menu.add(menuItem1);
  2. menu.add(menuItem2);
  3. menu.add(menuItem3);
  4. menu.addSeparator();
  5. menu.add(rbMenuItem1);
  6. menu.add(rbMenuItem2);
  7. menu.addSeparator();
  8. menu.add(cbMenuItem1);
  9. menu.add(cbMenuItem2);
  10. menu.addSeparator();
  11. menu.add(submenu);

将分隔符添加到工具栏是类似的。您可以在菜单工具栏的操作方法部分找到完整的代码。如果您想要更多地控制菜单和工具栏中的分隔符,可以直接使用实现它们的JSeparator子类: JPopupMenu.SeparatorJToolBar.Separator 。特别是,JToolBar.Separator具有用于指定分隔符大小的 API。

您可以直接使用JSeparator类在任何容器中提供分隔线。下图显示了一个 GUI,该按钮在标有 Fire 的按钮右侧有一个分隔符。

A snapshot of ListDemo

分隔符几乎没有 API,只要记住一件事就非常容易使用:在大多数实现中,垂直分隔符的首选高度为 0,水平分隔符的首选宽度为 0.这意味着分隔符不可见,除非您设置其首选大小或将其置于BorderLayoutBoxLayout等布局管理器的控制之下,该布局管理器将其拉伸以填充其可用显示区域。

垂直分隔符确实有一点宽度(水平位置有一点高度),因此您应该看到分隔符所在的空间。但是,除非宽度和高度均为非零,否则不绘制实际分割线。

以下代码段显示了 ListDemo 如何将包含垂直分隔符的面板放在一起。您可以在 ListDemo.java 中找到 ListDemo 的完整源代码。

  1. JPanel buttonPane = new JPanel();
  2. buttonPane.setLayout(new BoxLayout(buttonPane,
  3. BoxLayout.LINE_AXIS));
  4. buttonPane.add(fireButton);
  5. buttonPane.add(Box.createHorizontalStrut(5));
  6. buttonPane.add(new JSeparator(SwingConstants.VERTICAL));
  7. buttonPane.add(Box.createHorizontalStrut(5));
  8. buttonPane.add(employeeName);
  9. buttonPane.add(hireButton);
  10. buttonPane.setBorder(BorderFactory.createEmptyBorder(5,5,5,5));

如代码所示,按钮,分隔符和文本字段都共享一个容器 - 一个使用从左到右框布局JPanel实例。由于布局管理器(以及分隔符具有无限的最大尺寸),分隔符自动变为与其可用显示区域一样高。

在前面的代码中,水平支柱是用于在分隔符周围提供空间的不可见组件。 5 像素的空边框在面板周围提供缓冲,还用于防止分隔器一直延伸到其上方的组件和窗口下方的边缘。

这是另一个使用分隔符的 GUI 的图片,这次是在一组控件和显示区域之间放置一条分界线。

A snapshot of TextInputDemo

您可以在示例索引中找到代码。以下是设置分隔符容器的代码:

  1. JPanel panel = new JPanel(new BorderLayout());
  2. ...
  3. panel.setBorder(BorderFactory.createEmptyBorder(
  4. GAP/2, //top
  5. 0, //left
  6. GAP/2, //bottom
  7. 0)); //right
  8. panel.add(new JSeparator(JSeparator.VERTICAL),
  9. BorderLayout.LINE_START);
  10. panel.add(addressDisplay,
  11. BorderLayout.CENTER);

与上一个示例一样,面板使用空边框,以便分隔符不会一直延伸到其容器的边缘。将分隔符放置在BorderLayout控制容器的最左侧区域中使分隔符与容器中心的地址显示组件一样高。有关边框布局如何工作的详细信息,请参见如何使用 BorderLayout

使用分隔符的 API 很少,因为它们没有内容,也不响应用户输入。

构造器或方法 目的
void addSeparator()

void addSeparator(Dimension) (在JToolBar中) | 将工具栏分隔符(在大多数情况下,如果不是全部,看起来和感觉都不可见)附加到工具栏的当前末尾。可选参数指定分隔符的大小。此方法的无参数版本使用具有默认大小的分隔符,由当前外观确定。 | | void addSeparator() void insertSeparator(int) (在JMenu中) | 在菜单中放置一个分隔符。 addSeparator方法将分隔符放在菜单的当前末尾。 insertSeparator方法将分隔符插入到指定位置的菜单中。 | | void addSeparator() (在JPopupMenu中) | 在弹出菜单的当前末尾放置一个分隔符。 | | JSeparator() JSeparator(int) | 创建一个分隔符。如果未指定参数,则分隔符为水平。参数可以是SwingConstants.HORIZONTALSwingConstants.VERTICAL。 | | void setOrientation(int) int getOrientation() (在JSeparator中) | 获取或设置分隔符的方向,可以是SwingConstants.HORIZONTALSwingConstants.VERTICAL。 | | JToolBar.Separator() JToolBar.Separator(Dimension) | 创建一个分隔符以在工具栏中使用。可选参数指定分隔符的大小。 | | setSeparatorSize(Dimension) (在JToolBar.Separator中) | 指定分隔符的大小。更具体地说,指定的Dimension用作分隔符的最小,首选和最大尺寸。 | | JPopupMenu.Separator() | 创建一个在菜单中使用的分隔符。 |

本课程的一些示例使用分隔符,通常在菜单中。以下列出了一些更有趣的例子。

在哪里描述 笔记
ListDemo 本节和如何使用列表 在由水平框布局控制的面板中使用垂直分隔符。
TextInputDemo 本节和如何使用格式化文本字段 使用由边框布局控制的面板左侧的垂直分隔符。
MenuDemo 本节和如何使用菜单 使用JMenu方法addSeparator将分隔符放入菜单中。
ToolBarDemo2 如何使用工具栏 使用JToolBar方法addSeparator在两种按钮之间放置空格。

如果您使用 JavaFX 进行编程,请参阅使用 JavaFX UI 控件