JList with Image and text: Where text is coming from an ArrayList<String>
i have a simple example of a JList that is getting it's data from an ArrayList but i want to show an image next to each string in the list. I have written a custom cell renderer (IconListRenderer) that is suppose to display an icon and the object side-to-side.
Here is a running sample.
//Test class showing the list in a frame
import java.awt.Color;
import java.awt.Dimension;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import javax.swing.*;
import javax.swing.border.LineBorder;
public class Test extends JFrame{
public static void main(String[] args) {
final JFileChooser chooser = new JFileChooser();
JButton button = new JButton();
button.setText("Upload");
JFrame frame = new JFrame("My Frame");
JList list = new JList();
Map<Object, ImageIcon> icons = new HashMap<Object, ImageIcon>();
list.setBorder(new LineBorder(Color.BLACK));
ImageIcon icon = new ImageIcon("/Images/400px-Greek_uc_sigma.png");
ArrayList<String> arrayList = new ArrayList<String>();
icons.put("Name", icon);
//populate the arrayList for testing
arrayList.add("Smith");
arrayList.add("John");
arrayList.add("Bob");
arrayList.add("Kim");
frame.setSize(new Dimension(400, 400));
//set the list data
list.setListData(arrayList.toArray());
final JFrame imageFrame = new JFrame();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
list.se开发者_开发技巧tCellRenderer(new IconListRenderer(icons));
frame.add(list);
frame.setVisible(true);
frame.repaint();
}
}
//IconListRenderer class
import java.awt.Component;
import java.util.Map;
import javax.swing.DefaultListCellRenderer;
import javax.swing.Icon;
import javax.swing.ImageIcon;
import javax.swing.JLabel;
import javax.swing.JList;
public class IconListRenderer
extends DefaultListCellRenderer {
private Map<Object, ImageIcon> icons = null;
public IconListRenderer(Map<Object, ImageIcon> icons) {
this.icons = icons;
}
@Override
public Component getListCellRendererComponent(
JList list, Object value, int index,
boolean isSelected, boolean cellHasFocus) {
// Get the renderer component from parent class
JLabel label =
(JLabel) super.getListCellRendererComponent(list,
value, index, isSelected, cellHasFocus);
// Get icon to use for the list item value
Icon icon = icons.get(value);
// Set icon to display for value
label.setIcon(icon);
return label;
}
}
The list shows currently but no image?
It's not really surprising:
- you use the JList item value as a key to get the icon from the icon map;
- the icon map contains a single key: "Name"
- the JList contains "Smith", "John", "Bob" and "Kim", but no "Name"
精彩评论