我注意到,当一个元素被添加到 JList 并且该元素恰好落在选定的值范围内时,默认情况下它最终被选中。事实上,如果一个元素被添加到一个选定值的上方,它就会被添加到选择中。
我已经尝试查看 JList 代码(在开放的 JDK6 中)和 BasicListUI 代码,但我无法弄清楚为什么会发生这种情况或我需要做些什么来修复它的细节。
我正在考虑提供一个自定义的 SelectionModel,因为这将是在我的应用程序中做一些其他工作的明智之选,但我担心这可能会使问题变得更糟,或者更难解决。有谁知道为什么会这样?我能做些什么来解决它?
我创建了这个示例来演示该问题:
package jlistsscce;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
import javax.swing.DefaultListModel;
import javax.swing.JFrame;
import javax.swing.JList;
import javax.swing.JPanel;
public class JListSSCCE extends JPanel
{
private final JList list;
private ScheduledExecutorService ses;
public JListSSCCE()
{
list = new JList();
list.setModel(new DefaultListModel());
ses = Executors.newSingleThreadScheduledExecutor();
ses.scheduleAtFixedRate(new NewElement(), 100, 100, TimeUnit.MILLISECONDS);
add(list);
}
private static void createGui()
{
// create new JFrame
JFrame jf = new JFrame("JListSSCCE");
// this allows program to exit
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
// You add things to the contentPane in a JFrame
jf.getContentPane().add(new JListSSCCE());
// size frame
jf.pack();
// make frame visible
jf.setVisible(true);
}
public static void main(String[] args)
{
// threadsafe way to create a Swing GUI
javax.swing.SwingUtilities.invokeLater(new Runnable() {
@Override
public void run()
{
createGui();
}
}
);
}
private class NewElement implements Runnable
{
int n = 0;
@Override
public void run()
{
((DefaultListModel)list.getModel()).add((int)Math.floor(Math.sqrt(n)), ("hey"+n));
n++;
}
}
}