Home >Java >javaTutorial >How to Dynamically Switch UI Elements Based on ComboBox Selection Using Java\'s CardLayout?
How to Dynamically Alter UI Elements Based on ComboBox Selection
In graphical user interfaces (GUIs), it is often necessary to display different sets of controls depending on the selection made in a combo box. This article explores how to achieve this effect using Java's CardLayout.
Problem Definition:
In a dialog window, you need to show one group of controls when a particular combo box item is selected and a different group of controls when it is not selected. Essentially, you want to switch between two different layers of controls based on the combo box selection.
CardLayout Implementation:
CardLayout is a JPanel layout manager that allows multiple panels to be stacked on top of each other, with only one panel visible at a time. This makes it ideal for switching between different UI elements in response to external events.
Code Snippet:
The following Java code demonstrates how to use CardLayout to change UI elements based on combo box selection:
<code class="java">import java.awt.BorderLayout; import java.awt.CardLayout; import java.awt.Color; import java.awt.Dimension; import java.awt.EventQueue; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.util.Random; import javax.swing.JComboBox; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JPanel; public class CardPanel extends JPanel { private static final Random random = new Random(); private static final JPanel cards = new JPanel(new CardLayout()); private static final JComboBox combo = new JComboBox(); private final String name; public CardPanel(String name) { this.name = name; this.setPreferredSize(new Dimension(320, 240)); this.setBackground(new Color(random.nextInt())); this.add(new JLabel(name)); } @Override public String toString() { return name; } public static void main(String[] args) { EventQueue.invokeLater(new Runnable() { @Override public void run() { create(); } }); } private static void create() { JFrame f = new JFrame(); f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); for (int i = 1; i < 9; i++) { CardPanel p = new CardPanel("Panel " + String.valueOf(i)); combo.addItem(p); cards.add(p, p.toString()); } JPanel control = new JPanel(); combo.addActionListener(new ActionListener() { @Override public void actionPerformed(ActionEvent e) { JComboBox jcb = (JComboBox) e.getSource(); CardLayout cl = (CardLayout) cards.getLayout(); cl.show(cards, jcb.getSelectedItem().toString()); } }); control.add(combo); f.add(cards, BorderLayout.CENTER); f.add(control, BorderLayout.SOUTH); f.pack(); f.setLocationRelativeTo(null); f.setVisible(true); } }</code>
Explanation:
The above is the detailed content of How to Dynamically Switch UI Elements Based on ComboBox Selection Using Java\'s CardLayout?. For more information, please follow other related articles on the PHP Chinese website!