我有一个扩展JComponent的自定义组件。单击它时,它会使用MouseListener捕获事件。根据组件的状态和单击的位置,存储在其中的数据会更新。
如何在发生这种情况时通知父容器,同时保持其完全独立?
答案 0 :(得分:3)
我自己,我会使用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+到user129 ...但是我喜欢PCL的是我可以指定要监听的属性名称,允许我监听多个不同状态的变化,这样就可以从MVC设计中创建一个完整的视图。与Control完全分离。所以我的建议是:如果你只是听一个状态,那么一定要使用ChangeListener,但是如果你正在听多个状态,那就使用PCL。
答案 1 :(得分:2)
您可以使用ChangeListener,它应该适合您