我的 GUI 中有多个组合框,它们都需要数据。这些数据会随机变化,因此需要一种快速方法来保持所有值同步。我遇到了 DefaultComboBoxModel,它实际上非常适合。唯一的问题是,我需要组合框彼此独立 - 这意味着:如果我在其中选择一个值,则所有其他组合框不应更改。
我做了一些研究并阅读了标准的 java 教程,但没有人真正告诉我如何使用 DefaultComboBoxModel 来实现这一点。
这里的这个例子准确地说明了我所需要的:在两个 JComboBox 之间共享数据模型 http://www.java2s.com/Tutorial/Java/0240__Swing/SharingtheDataModelbetweentwoJComboBoxes.htm但选择其中之一时,两者的 selectedindex 不应同时更改。
这个问题 https://stackoverflow.com/questions/13455767/shared-data-between-two-comboboxes已经问过类似的问题,但我不知道如何处理“装饰”。
有什么办法可以防止更改,或者例如仅使用普通数组来同步值?
也许有人可以用鱼快速打我的脸,因为解决方案可能非常简单......
我认为这就是罗宾在您的帖子中提到的答案中所解释的。您将原始组合框模型包装成 2 个独立的组合框模型,这些模型依赖于原始组合框模型的数据元素,但实现了自己的选择模型。
import java.awt.BorderLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.ComboBoxModel;
import javax.swing.DefaultComboBoxModel;
import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.SwingUtilities;
import javax.swing.event.ListDataEvent;
import javax.swing.event.ListDataListener;
public class SharedDataBetweenComboBoxSample {
public static class MyComboBoxModel extends DefaultComboBoxModel implements ComboBoxModel, ListDataListener {
private DefaultComboBoxModel original;
public MyComboBoxModel(DefaultComboBoxModel original) {
super();
this.original = original;
}
@Override
public int getSize() {
return original.getSize();
}
@Override
public Object getElementAt(int index) {
return original.getElementAt(index);
}
@Override
public void addListDataListener(ListDataListener l) {
if (getListDataListeners().length == 0) {
original.addListDataListener(this);
}
super.addListDataListener(l);
}
@Override
public void removeListDataListener(ListDataListener l) {
super.removeListDataListener(l);
if (getListDataListeners().length == 0) {
original.removeListDataListener(this);
}
}
@Override
public void addElement(Object anObject) {
original.addElement(anObject);
}
@Override
public void removeElement(Object anObject) {
original.removeElement(anObject);
}
@Override
public int getIndexOf(Object anObject) {
return original.getIndexOf(anObject);
}
@Override
public void insertElementAt(Object anObject, int index) {
original.insertElementAt(anObject, index);
}
@Override
public void removeAllElements() {
original.removeAllElements();
}
@Override
public void removeElementAt(int index) {
original.removeElementAt(index);
}
@Override
public void intervalAdded(ListDataEvent e) {
fireIntervalAdded(this, e.getIndex0(), e.getIndex1());
}
@Override
public void intervalRemoved(ListDataEvent e) {
fireIntervalRemoved(this, e.getIndex0(), e.getIndex1());
}
@Override
public void contentsChanged(ListDataEvent e) {
fireContentsChanged(this, e.getIndex0(), e.getIndex1());
}
}
public static void main(String args[]) {
SwingUtilities.invokeLater(new Runnable() {
@Override
public void run() {
final String labels[] = { "A", "B", "C", "D", "E", "F", "G" };
final DefaultComboBoxModel model = new DefaultComboBoxModel(labels);
JFrame frame = new JFrame("Shared Data");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
JPanel panel = new JPanel();
JComboBox comboBox1 = new JComboBox(new MyComboBoxModel(model));
comboBox1.setEditable(true);
JComboBox comboBox2 = new JComboBox(new MyComboBoxModel(model));
comboBox2.setEditable(true);
panel.add(comboBox1);
panel.add(comboBox2);
frame.add(panel, BorderLayout.NORTH);
JButton button = new JButton("Add");
frame.add(button, BorderLayout.SOUTH);
ActionListener actionListener = new ActionListener() {
@Override
public void actionPerformed(ActionEvent actionEvent) {
model.addElement("New Added");
}
};
button.addActionListener(actionListener);
frame.pack();
frame.setVisible(true);
}
});
}
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)