我有一个简单的POJO:
class A{
private int a;
private int b;
public int getC(){
return a + b;
}
//getters and setters for a and b
}
此实体使用BindingBeans绑定到JTable。对a和b所做的任何更改都会在JTable中正确处理并显示,但是c不会更新。
我认为如果更新a或b,我需要触发属性更改事件,但实际上没有任何想法。有什么想法吗?
编辑:
我创建了一个简单的例子:
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import java.io.Serializable;
public class POJO implements Serializable{
private static final Gson gson = new GsonBuilder().create();
private Integer a;
private Integer b;
public Integer getC() {
return a + b;
}
public Integer getA() {
return a;
}
public void setA(Integer a) {
this.a = a;
}
public Integer getB() {
return b;
}
public void setB(Integer b) {
this.b = b;
}
@Override
public String toString(){
return gson.toJson(this);
}
}
主要课程
import java.awt.BorderLayout;
import java.awt.GridLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.ArrayList;
import java.util.List;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JTable;
import org.jdesktop.beansbinding.AutoBinding;
import org.jdesktop.beansbinding.BeanProperty;
import org.jdesktop.swingbinding.JTableBinding;
import org.jdesktop.swingbinding.SwingBindings;
public class Example implements ActionListener{
private JTable table;
private JFrame frame;
private JTableBinding tableBinding;
private List<POJO> elements;
public static void main(String [] args){
new Example();
}
public Example(){
initData();
initGui();
initBindings();
frame.pack();
}
private void initData(){
elements = new ArrayList<POJO>();
POJO pojoA = new POJO();
pojoA.setA(1);
pojoA.setB(2);
POJO pojoB = new POJO();
pojoB.setA(3);
pojoB.setB(4);
elements.add(pojoA);
elements.add(pojoB);
}
private void initGui(){
frame = new JFrame();
table = new JTable();
frame.getContentPane().setLayout(new BorderLayout());
JPanel tablePanel = new JPanel();
tablePanel.setLayout(new GridLayout());
tablePanel.add(table);
frame.getContentPane().add(BorderLayout.CENTER,tablePanel);
JButton button = new JButton("Show Current Elements");
button.addActionListener(this);
frame.getContentPane().add(BorderLayout.SOUTH,button);
frame.setLocationRelativeTo(null);
frame.setVisible(true);
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
}
private void initBindings(){
tableBinding = SwingBindings.createJTableBinding(
AutoBinding.UpdateStrategy.READ_WRITE, elements,
table);
addBinding("a", "A", Integer.class, true);
addBinding("b", "B", Integer.class, true);
addBinding("c", "C", Integer.class, false);
tableBinding.bind();
}
private void addBinding(String properyName, String columnName, Class clazz, boolean editable) {
BeanProperty beanProperty = BeanProperty.create(properyName);
JTableBinding.ColumnBinding columnBinding = tableBinding.addColumnBinding(beanProperty);
columnBinding.setColumnName(columnName);
columnBinding.setColumnClass(clazz);
columnBinding.setEditable(editable);
}
public void actionPerformed(ActionEvent ae) {
StringBuilder builder = new StringBuilder();
for(POJO pojo : elements){
builder.append(pojo.toString() + "\n");
}
JOptionPane.showMessageDialog(null, "The elements are:\n\n" + builder.toString());
}
}
答案 0 :(得分:2)
为了拥有正确的bean,您需要触发事件
private final PropertyChangeSupport = new PropertyChangeSupport( this );
public void setA(Integer a) {
Integer old = this.a;
this.a = a;
propertyChangeSupport.firePropertyChange( "A", old, this.a );
}
C是派生属性。如果你只有一个吸气剂而没有二传手,那么不确定它是否会起作用。但是,如果C发生变化,您很可能需要触发事件。由于它在A或B改变时发生变化,我会将其setter更新为
public void setA(Integer a) {
Integer oldA = this.a;
Integer oldC = getC();
this.a = a;
propertyChangeSupport.firePropertyChange( "A", oldA, this.a );
propertyChangeSupport.firePropertyChange( "C", oldC, getC() );
}
同样适用于B物业。
但如前所述,我没有使用该绑定框架的经验。所以不确定这是否会解决您的问题而我还没有对其进行测试(不打算先下载/安装该框架)。