我有一个扩展 JComponent 的自定义组件。当您单击它时,它会使用 MouseListener 捕获事件。根据组件的状态和您单击的位置,存储在其中的数据会更新。
发生这种情况时如何通知父容器,同时保持它完全独立?
我自己,我会使用 JComponent 附带的 PropertyChangeSupport,然后在程序状态发生变化时触发你的 notify 方法。
例如:
import java.awt.BorderLayout;
import java.awt.FlowLayout;
import java.awt.event.ActionEvent;
import java.beans.PropertyChangeEvent;
import java.beans.PropertyChangeListener;
import javax.swing.*;
public class PropChangeEg {
private static void createAndShowGui() {
final JLabel counterLabel = new JLabel(" ", SwingConstants.CENTER);
CustomComponent myCustomComponent = new CustomComponent();
myCustomComponent.addPropertyChangeListener(new PropertyChangeListener() {
@Override
public void propertyChange(PropertyChangeEvent pcEvt) {
if (pcEvt.getPropertyName().equals(CustomComponent.COUNTER)) {
String text = "Counter: " + pcEvt.getNewValue();
counterLabel.setText(text);
}
}
});
JFrame frame = new JFrame("PropChangeEg");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.add(myCustomComponent, BorderLayout.CENTER);
frame.add(counterLabel, BorderLayout.PAGE_END);
frame.pack();
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
public static void main(String[] args) {
SwingUtilities.invokeLater(new Runnable() {
public void run() {
createAndShowGui();
}
});
}
}
@SuppressWarnings("serial")
class CustomComponent extends JComponent {
public static final String COUNTER = "counter";
private int counter = 0;
public CustomComponent() {
setLayout(new FlowLayout());
add(new JButton(new AbstractAction("Increment Counter") {
@Override
public void actionPerformed(ActionEvent arg0) {
setCounter(counter + 1);
}
}));
add(new JButton(new AbstractAction("Decrement Counter") {
@Override
public void actionPerformed(ActionEvent arg0) {
setCounter(counter - 1);
}
}));
}
//@Override // not needed!!
//public void addPropertyChangeListener(PropertyChangeListener listener) {
// super.addPropertyChangeListener(listener);
//}
//@Override // not needed!!
//public void removePropertyChangeListener(PropertyChangeListener listener) {
// super.removePropertyChangeListener(listener);
//}
public void setCounter(int counter) {
int oldValue = this.counter;
int newValue = counter;
this.counter = newValue;
firePropertyChange(COUNTER, oldValue, newValue);
}
public int getCounter() {
return counter;
}
}
关于评论:
ChangeListener 也可以正常工作。1+ to user129 ...但我喜欢PCL的地方是我可以指定要监听的属性的名称,让我可以监听多个不同状态的变化,这样可以从MVC设计创建一个完整的视图与控制完全解耦。所以我的建议是:如果你只收听一个状态,那么一定要使用 ChangeListener,但如果你要收听多个状态,请使用 PCL。
你可以使用 ChangeListener 它应该为你工作