我正在使用ListCellRenderer来编辑JList中条目的外观。一旦选中它们(通过单击它们,此代码在单击事件中)我调用ListCellRenderer来更改文本的颜色。如果再次选择它们,我希望文本返回正常颜色。我遇到的问题是,一旦我选择第二个条目,第一个条目就会回到正常颜色。如何将所选颜色保留为所选颜色,直到实际取消选择它们为止?这是我实际调用函数的部分:
for(int i = 0; i < selectedEntries.size() - 1; i++){
System.out.println("Inside the for loop at entry:" + i);
if(selectedEntries.get(i).equals(selectedEntry)){
selectedEntries.remove(i);
removed = true;
renderer.getListCellRendererComponent(logEntries, value, index, false, false);
System.out.println("Duplicate Entry Removed From List");
}
}
if(!removed){
selectedEntries.add(selectedEntry);
renderer.getListCellRendererComponent(logEntries, value, index, true, false);
}
为了便于解释,selectedEntries是一个包含每个选定条目文本的ArrayList。
答案 0 :(得分:3)
选择它们后(通过单击它们,此代码在单击事件中)我调用ListCellRenderer来更改文本的颜色
不,这不是它应该如何运作,ListCellRenderer
将再次被调用(JList
),而isSelected
参数将是true
,你可以会以不同的方式呈现值
ListCellRenderer
负责呈现选定或未选中的整个州。
有关详细信息,请查看Writing a Custom Cell Renderer
例如
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Component;
import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.Font;
import javax.swing.DefaultListCellRenderer;
import javax.swing.DefaultListModel;
import javax.swing.JFrame;
import javax.swing.JList;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
public class Test {
public static void main(String[] args) {
new Test();
}
public Test() {
EventQueue.invokeLater(new Runnable() {
@Override
public void run() {
try {
UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
} catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
ex.printStackTrace();
}
JFrame frame = new JFrame("Testing");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.add(new TestPane());
frame.pack();
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
});
}
public class TestPane extends JPanel {
public TestPane() {
setLayout(new BorderLayout());
DefaultListModel<String> model = new DefaultListModel<>();
model.addElement("Apples");
model.addElement("Bananas");
model.addElement("Peachs");
model.addElement("Pears");
JList<String> listOfStrings = new JList<>(model);
listOfStrings.setCellRenderer(new FancyPancyListCellRenderer());
add(new JScrollPane(listOfStrings));
}
@Override
public Dimension getPreferredSize() {
return new Dimension(200, 200);
}
}
public static class FancyPancyListCellRenderer extends DefaultListCellRenderer {
protected static final Font SELECTED_FONT = new Font("Comic Sans MS", Font.PLAIN, 12);
@Override
public Component getListCellRendererComponent(JList<?> list, Object value, int index, boolean isSelected, boolean cellHasFocus) {
super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
if (isSelected) {
setForeground(Color.YELLOW);
setFont(SELECTED_FONT);
} else {
setFont(UIManager.getFont("Label.font"));
}
return this;
}
}
}
此外,MouseListener
实际上不是检测选择更改的合适方法,如果用户使用键盘选择行会发生什么?您应该使用ListSelectionListener
代替(但不能更正此问题)。
有关详细信息,请查看How to Write a List Selection Listener和How to Use Lists