如何使用 CardLayout

原文: https://docs.oracle.com/javase/tutorial/uiswing/layout/card.html


Note: This lesson covers writing layout code by hand, which can be challenging. If you are not interested in learning all the details of layout management, you might prefer to use the GroupLayout layout manager combined with a builder tool to lay out your GUI. One such builder tool is the NetBeans IDE. Otherwise, if you want to code by hand and do not want to use GroupLayout, then GridBagLayout is recommended as the next most flexible and powerful layout manager.


如果您对使用 JavaFX 创建 GUI 感兴趣,请参阅在 JavaFX 中使用布局。

下图表示使用 CardLayout 类在两个面板之间切换的应用程序的快照。

A snapshot of CardLayoutDemo Another snapshot of CardLayoutDemo

单击“启动”按钮以使用 Java™Web Start下载 Java SE )运行 CardLayoutDemo。或者,要自己编译并运行示例,请参考示例索引

Launches the CardLayoutDemo application

该演示的完整代码位于 CardLayoutDemo.java 文件中。

CardLayout类管理共享相同显示空间的两个或多个组件(通常是JPanel实例)。使用CardLayout类时,让用户使用组合框在组件之间进行选择。 CardLayoutDemo应用程序是用于说明此功能的示例。

完成相同任务的另一种方法是使用选项卡式窗格。下图显示了上一个示例的选项卡式窗格版本:

A snapshot of TabDemo

由于选项卡式窗格提供了自己的 GUI,因此使用选项卡式窗格比使用CardLayout类更简单。例如,使用选项卡式窗格实现前面的示例会导致程序包含更少的代码行。

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

Launches the TabDemo application

该演示的完整代码位于 TabDemo.java 文件中。

从概念上讲,CardLayout管理的每个组件就像一个堆叠中的扑克牌或交易卡,其中只有顶部卡片随时可见。您可以选择以下列任何一种方式显示的卡片:

  • 通过要求第一张或最后一张卡,按顺序将其添加到容器中
  • 通过向后或向前翻转甲板
  • 通过指定具有特定名称的卡

CardLayoutDemo类使用最后一个方案。

CardLayoutDemo.java 应用程序的以下代码片段创建CardLayout对象及其管理的组件。

  1. //Where instance variables are declared:
  2. JPanel cards;
  3. final static String BUTTONPANEL = "Card with JButtons";
  4. final static String TEXTPANEL = "Card with JTextField";
  5. //Where the components controlled by the CardLayout are initialized:
  6. //Create the "cards".
  7. JPanel card1 = new JPanel();
  8. ...
  9. JPanel card2 = new JPanel();
  10. ...
  11. //Create the panel that contains the "cards".
  12. cards = new JPanel(new CardLayout());
  13. cards.add(card1, BUTTONPANEL);
  14. cards.add(card2, TEXTPANEL);

要将组件添加到CardLayout对象管理的容器,请指定标识要添加的组件的字符串。例如,在此演示中,第一个面板具有字符串"Card with JButtons",第二个面板具有字符串"Card with JTextField"。在此演示中,这些字符串也在组合框中使用。

要选择CardLayout对象显示的组件,请在代码示例中添加其他代码:

  1. //Where the GUI is assembled:
  2. //Put the JComboBox in a JPanel to get a nicer look.
  3. JPanel comboBoxPane = new JPanel(); //use FlowLayout
  4. String comboBoxItems[] = { BUTTONPANEL, TEXTPANEL };
  5. JComboBox cb = new JComboBox(comboBoxItems);
  6. cb.setEditable(false);
  7. cb.addItemListener(this);
  8. comboBoxPane.add(cb);
  9. ...
  10. pane.add(comboBoxPane, BorderLayout.PAGE_START);
  11. pane.add(cards, BorderLayout.CENTER);
  12. ...
  13. //Method came from the ItemListener class implementation,
  14. //contains functionality to process the combo box item selecting
  15. public void itemStateChanged(ItemEvent evt) {
  16. CardLayout cl = (CardLayout)(cards.getLayout());
  17. cl.show(cards, (String)evt.getItem());
  18. }

此示例显示要使用CardLayout类的show方法,必须设置当前可见的组件。 show方法中的第一个参数是CardLayout控制的容器 - 即CardLayout管理的组件的容器。第二个参数是标识要显示的组件的字符串。此字符串与将组件添加到容器时使用的字符串相同。

下表列出了用于选择组件的CardLayout类方法。对于每个方法,第一个参数是CardLayout是布局管理器的容器(CardLayout控制的卡的容器)。

方法 目的
首先 (容器*父*) 翻转到容器的第一张卡片。
下一个(容器*父*) 翻转到容器的下一张卡片。如果当前可见的卡是最后一张,则此方法将翻转到布局中的第一张卡。
previous(Container _parent_ ) 翻转到容器的上一张卡片。如果当前可见的卡是第一张,则此方法将翻转到布局中的最后一张卡。
最后(容器*父*) 翻转到容器的最后一张卡片。
显示(容器*父*,字符串*名称*) 使用 addLayoutComponent 方法翻转到使用指定的name添加到此布局的组件。

此路径中只有一个示例使用CardLayout,这是 CardLayoutDemo 。通常,我们的示例使用选项卡式窗格而不是CardLayout,因为选项卡式窗格提供了自己的 GUI。